var versionPdf = 2; var urlSite="https://chinginfo.fr"; var local = false; function chap_affExo(){ console.log("chap_affExo"); /* ev.preventDefault(); ev.stopPropagation(); //=== Enonce ou correction var e; if(ev.currentTarget.getAttribute('affEnonce')==null){ e=0; } else{ e=1; } //=== Affiche le div var num = ev.currentTarget.getAttribute("numexo"); */ //Affiche l'exercice var elt = document.getElementById('chap_exo'); elt.style.display='block'; //blur le body document.querySelector("#aff").style.filter="blur(2px)"; document.querySelector("#navigation").style.filter="blur(2px)"; //document.querySelector("#navPlus").style.filter="blur(2px)"; //Lance l'animation elt.style.animation = "2s linear 0s correcExo_anim_in" elt.style.left="50%" //=== Stoppe le defilement du mpdfPrinc //pdfPrinc.scrollOff = true; //=== Ancien pdfCorrec= new mpdf("chap_exoAff",true); //mpdf.col=sd_getCol; pdfCorrec.col = 1; pdfCorrec.zoomStrict = true; pdfCorrec.preparePdf(); var e = 1; pdfCorrec.chargePdf(urlSite+'/chap_exoAff.php?n='+exoNum+'&e='+e) /* var num = ev.currentTarget.getAttribute("numcorrec") var elt = document.createElement('a'); elt.setAttribute('href',urlSite+'/exercice.php?n='+num) elt.setAttribute('download',"ChingInfo-"+num+".pdf") document.body.appendChild(elt) elt.click() document.body.removeChild(elt) return false; */ } function chap_affCorrec(ev){ console.log("chap_affCorrec"); ev.preventDefault(); ev.stopPropagation(); //=== Enonce ou correction var e; if(ev.currentTarget.getAttribute('affEnonce')==null){ e=0; } else{ e=1; } //=== Affiche le div var num = ev.currentTarget.getAttribute("numexo"); //Affiche l'exercice var elt = document.getElementById('chap_exo'); elt.style.display='block'; //blur le body document.querySelector("#aff").style.filter="blur(2px)"; document.querySelector("#navigation").style.filter="blur(2px)"; //document.querySelector("#navPlus").style.filter="blur(2px)"; //Lance l'animation elt.style.animation = "2s linear 0s correcExo_anim_in" elt.style.left="50%" //=== Stoppe le defilement du mpdfPrinc //pdfPrinc.scrollOff = true; //=== Ancien pdfCorrec= new mpdf("chap_exoAff",true); //mpdf.col=sd_getCol; pdfCorrec.col = 1; pdfCorrec.zoomStrict = true; pdfCorrec.preparePdf(); pdfCorrec.chargePdf(urlSite+'/chap_exoAff.php?n='+num+'&e='+e) /* var num = ev.currentTarget.getAttribute("numcorrec") var elt = document.createElement('a'); elt.setAttribute('href',urlSite+'/exercice.php?n='+num) elt.setAttribute('download',"ChingInfo-"+num+".pdf") document.body.appendChild(elt) elt.click() document.body.removeChild(elt) return false; */ } function chap_exoFerme(){ console.log("chap_correcFerme"); /* if(mpdfPrinc == null) return; mpdfPrinc.scrollOff = false; */ //blur le body document.querySelector("#aff").style.filter="none"; document.querySelector("#navigation").style.filter="none"; //Ferme la fenetre d'exercice var elt = document.getElementById('chap_exo'); elt.style.animation = "1s linear 0s correcExo_anim_out" elt.style.left="-150%" }function exo_aff(ev){ ev.preventDefault(); var elt = ev.currentTarget; num=elt.getAttribute('num'); // ==== Affichage du block document.querySelector('#affExo').style.display="block" // ==== Chargement du pdf pdfExo.affichePdf('e'+num); }var pdfChap = null; var pdfExo; var pdfCorrec; var classeNum = 0; var chapNum = 0; var exoNum = 0; var correcNum = 0; console.log("AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA"); var pdfDownload = null; window.exoSacAdos = [] function loadMyPdf(){ console.log("loadMyPdf") //Rejout le style de Aff var elt = document.querySelector("#aff"); elt.style.width="auto" elt.style.borderWidth="2px" //Demarre les deux pdf pdfChap = new mpdfInfo("aff",true); pdfChap.zoomStrict=true; pdfChap.col=1; pdfCorrec = new mpdfInfo("chap_exoAff",true); pdfCorrec.zoomStrict = true; pdfExo = new mpdfInfo("affExo",true); pdfSacados = new mpdfInfo("aff",true); } function loadInit() { console.log('loadInit'); navBouton(); //Fermeture du div pour affichage exo/correc var elt = document.querySelector('#affExo'); if (elt != null) { elt.addEventListener('click', function (ev) { ev.currentTarget.style.display = "none"; }); } //==== Ouvre une classe if(classeNum != 0){ classeAff(classeNum); } //==== Ouvre un chapitre if (chapNum != 0) { console.log('Ouvre un chapitre : '+chapNum+' '+chapUrl) chapitreAff(chapNum,chapUrl); } //==== Ouvre la correction if(correcNum!=0){ console.log("YUUUUUUUUUUUUUUUUUUUUUU correctyion"); var obj = new Object(); obj.preventDefault = function(){}; obj.stopPropagation = function(){}; var div = document.createElement("div1"); div.setAttribute("numcorrec",correcNum); div.setAttribute("affEnonce",1); obj.currentTarget = div; chap_affCorrec(obj);//"resultat/compilation/chap" + chapNum + ".pdf") } //==== Ouvre un exercice if(exoNum!=0){ console.log("YUUUUUUUUUUUUUUUUUUUUUU exercuce"); /* var obj = new Object(); obj.preventDefault = function(){}; obj.stopPropagation = function(){}; var div = document.createElement("div1"); div.setAttribute("numcorrec",exoNum); div.setAttribute("affEnonce",1); obj.currentTarget = div; */ chap_affExo();//"resultat/compilation/chap" + chapNum + ".pdf") } //==== Bouton download var elt = document.querySelector("#downloadPdf"); if(elt!=null){ elt.addEventListener('click',download_pdf) elt.querySelector(':nth-child(1)').src = image_pdf elt.querySelector(':nth-child(2)').src = image_direction1 } //==== Double-clic pour fermer le dialogue var elt = document.querySelector('#chap_exo') if(elt != undefined){ elt.addEventListener('dblclick',chap_exoFerme); } } var g_diagTimeout=null; function diagMessage(x){ var elt = document.getElementById('diagMessage'); if(x.substring(0,7)=="Erreur:"){ x = x.substring(7); elt.style.backgroundColor="lightcoral"; } else{ elt.style.backgroundColor="mediumturquoise"; } elt.innerHTML=x; elt.style.display="block"; g_diagTimeout = setTimeout(diagMessage_out,3000); } function diagMessage_out(){ if(g_diagTimeout!=null){ document.getElementById('diagMessage').style.display="none"; g_diagTimeout = null; } } function download_pdf(e){ console.log("download_pdf") //=== Aucun fichier à télécharger if(pdfDownload==null){ diagMessage("Erreur:Aucun fichier à télécharger"); return; } //=== Téléchargement du fichier var elt = document.createElement('a'); elt.setAttribute('href',urlSite+'/download_pdf.php?d='+pdfDownload) elt.setAttribute('download',null) document.body.appendChild(elt) elt.click() document.body.removeChild(elt) /* var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function() { if (this.readyState == 4){ if (xhr.status === 200) { if(xhr.responseText.substring(0,7)=="Erreur:"){ diagMessage(xhr.responseText); return; } var elt = document.createElement('a'); } } } xhr.open('POST', urlSite+'/download_pdf.php', false); xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); xhr.send("d="+pdfDownload); */ } window.addEventListener('load', loadInit); zoomListe = [400,500,600,700,800,900,1000,1100,1200,1300,1400,1500] zoomNum = 4 function affZoomChange(delta){ console.log("affZoomChange"); if(pdfChap==null){ return; } zoomNum += delta; if(zoomNum<0){ zoomNum = 0; } if(zoomNum>=zoomListe.length){ zoomNum = zoomListe.length-1; } document.querySelector("#supAff").style.maxWidth=zoomListe[zoomNum]+"px" pdfChap.resizeWindow() } /*================ SCript jx de ChingAtome =================*/ window.jx = function (url, cible, arg = {}) { //Construction de l'history console.log("jx " + url + " " + cible + " " + arg); if ((url.indexOf('.php') == -1) && (cible == "sousAff") && (arg["noHistory"] == undefined)) { urlHistory = url.replace('/cl/', '/classe/'); urlHistory = urlHistory.replace('/ch/', '/chapitre/'); urlHistory = urlHistory.replace('/info/', '/informatique/'); urlHistory = urlHistory.replace('/apropos/', '/a_propos/'); urlHistory = urlHistory.replace('/sacados/', '/sac-a-dos/'); urlHistory = urlHistory.replace('/divers/', '/divers-info/'); urlHistory = urlHistory.replace('/exo/', '/'); urlHistory = urlHistory.replace('/rsrc', '/ressource'); urlHistory = urlHistory.replace('/espaceProf/', '/espace/'); if (urlHistory.indexOf("vos-feuilles?af=") != -1) { y = urlHistory.split("?af"); urlHistory = y[0] } history.pushState(url, null, urlHistory); //history.replaceState(null,null,urlHistory); } //Affichage spécial "#sousAff" if (cible == 'sousAff') { //document.getElementById("navPlus").innerHTML=""; //document.getElementById("navPlus").style.height="initial"; document.getElementById('aff').scrollTo(0, 0); } //xmlhttprequest var xhr_object = null; if (window.XMLHttpRequest) // Firefox xhr_object = new XMLHttpRequest(); else if (window.ActiveXObject) // Internet Explorer xhr_object = new ActiveXObject('Microsoft.XMLHTTP'); else { // XMLHttpRequest non supporté par le navigateur alert('Votre navigateur ne supporte pas les objets XMLHTTPRequest...'); return; } xhr_object.onreadystatechange = function () { if ((cible == null) || (typeof document.getElementById(cible) == undefined)) return; //if((xhr_object.readyState == 4) && (xhr_object.status===200)){ if ((xhr_object.readyState == 4) && (xhr_object.status !== 2)) { //document.title=this.url if (cible == 'ssssssssousAff') { clearInterval(boucleChargement); window.scrollTo(0, 0); //Desactive vielle feuille style a = document.styleSheets for (i = 2; i < a.length; i++) { a[i].disabled = true; } } setInnerHTML(document.getElementById(cible), xhr_object.responseText) //document.getElementById(cible).innerHTML=xhr_object.responseText //=== Arg option if (arg["scrollTo"] != undefined) { document.getElementById('sousAff').scroll(0, arg["scrollTo"]); } } } //Invocation de l'ajax xhr_object.url = url; //console.log("xxxxxxxx "+url) //url="https://chinginfo.fr/dossier/weblinux/index.php"; xhr_object.open('GET', url, true); //xhr_object.setRequestHeader('Content-Type', 'text/xml; charset=UTF-8'); xhr_object.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8'); xhr_object.send(); } function insertScript($script, callback) { var s = document.createElement('script') s.type = 'text/javascript' if ($script.src) { s.onload = callback s.onerror = callback s.src = $script.src } else { s.textContent = $script.innerText } // re-insert the script tag so it executes. document.head.appendChild(s) // clean-up $script.parentNode.removeChild($script) // run the callback immediately for inline scripts if (!$script.src) { callback() } } function runScripts($container) { // get scripts tags from a node var $scripts = $container.querySelectorAll('script') var runList = [] var typeAttr [].forEach.call($scripts, function ($script) { typeAttr = $script.getAttribute('type') // only run script tags without the type attribute // or with a javascript mime attribute value if (!typeAttr || runScriptTypes.indexOf(typeAttr) !== -1) { runList.push(function (callback) { insertScript($script, callback) }) } }) // insert the script tags sequentially // to preserve execution order if (runList.length != 0) { seq(runList, scriptsDone) } } // trigger DOMContentLoaded function scriptsDone() { var DOMContentLoadedEvent = document.createEvent('Event') DOMContentLoadedEvent.initEvent('DOMContentLoaded', true, true) document.dispatchEvent(DOMContentLoadedEvent) } // runs an array of async functions in sequential order function seq(arr, callback, index) { // first call, without an index if (typeof index === 'undefined') { index = 0 } arr[index](function () { index++ if (index === arr.length) { callback() } else { seq(arr, callback, index) } }) } var runScriptTypes = [ 'application/javascript', 'application/ecmascript', 'application/x-ecmascript', 'application/x-javascript', 'text/ecmascript', 'text/javascript', 'text/javascript1.0', 'text/javascript1.1', 'text/javascript1.2', 'text/javascript1.3', 'text/javascript1.4', 'text/javascript1.5', 'text/jscript', 'text/livescript', 'text/x-ecmascript', 'text/x-javascript' ] // setInnerHTML Sécurisé function setInnerHTML(divContent, HTML) { divContent.innerHTML = HTML; runScripts(divContent) }var sac_a_dos = ""; var image_direction1 = "" var image_pdf = "" function navBouton() { //Active les boutons de classedivCon var liste = document.querySelectorAll('#navigation > div'); for (var i = 0; i < liste.length; i++) { console.log(liste[i].parentNode.getAttribute('cl')) console.log(liste[i].parentNode) if (liste[i].getAttribute('cl') == null) continue; liste[i].addEventListener('click', classeClick); } //Active les boutons de chapitre var liste = document.querySelectorAll("#navigation > div > :nth-child(2) > div"); for (var i = 0; i < liste.length; i++) { liste[i].addEventListener('click', chapitreClick); } //Affiche le sac à dos : var elt = document.querySelector('#navigation > :nth-child(16)'); if (elt != null) { console.log("kk") elt.firstChild.src = sac_a_dos elt.addEventListener('click', sacAdos_aff) } } function classeClick(ev) { var cl = ev.currentTarget.getAttribute('cl'); console.log('classeClick ' + cl); classeAff(cl) } function classeAff(cl) { // Formate la page document.querySelector('#aff').style = "" displayPdfTools(false) lienAccueil(true); //Recupere le contenu de la classe var content; if ((chapitre[cl] == undefined) || (chapitre[cl].length == 0)) { content = 'Aucun chapitre pour le moment'; } else { var chap = chapitre[cl]; //==== Titre content = '
' + chap[0][1] + '
' //==== content += ''; history.replaceState(null, null, urlSite + "/classe/" + chap[0][2]); } //Ecriture du corps document.querySelector('#aff').innerHTML = content; activeClasse(); // Changement url } function activeClasse() { console.log("activeClasse A FAIRE") var liste = document.querySelectorAll('#navChap > li') for (var i = 0; i < liste.length; i++) { liste[i].addEventListener('click', chapitreClick) } } function chapitreClick(ev) { var url = ev.currentTarget.getAttribute('url') var num = ev.currentTarget.getAttribute('num') console.log('chapitreClick ',url); if (url == null) { console.log('chapitreClick /dossier - ',url); //=== Ouverture du dossier var elt = document.createElement('a'); elt.setAttribute('href','https://' + ev.currentTarget.getAttribute('dossier') + '.chinginfo.'+(local?'local':'fr')); elt.target='chinginfo' elt.style.display = "none"; document.body.appendChild(elt) elt.click() //document.body.removeChild(elt) } else { console.log('chapitreClick / chapitre - ',url); chapitreAff(num, url); } } function chapitreAff(chapNum, url) { console.log("chapitreAff " + chapNum + " " + url) //Formatage de la page document.querySelector('#aff').style.borderWidth = "2px" displayPdfTools(true) lienAccueil(false); //Ajoute dans l'historique //var url = urlSite + '/chap/' + url; history.pushState(null, null, urlSite + '/chapitre/' + url); if (pdfChap == null) { loadMyPdf(); } //Ouvre le chap var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function () { if (this.readyState == 4) { if (xhr.status === 200) { if (xhr.responseText.substring(0, 7) == "Erreur:") { diagMessage(xhr.responseText); } else { pdfChap.preparePdf(); pdfChap.chargePdf(urlSite + '/resultat/cache/chap' + chapNum + '-0.b64'); pdfChap.scrollY = 0; pdfChap.counterdown = "chap" pdfDownload = '/resultat/cache/chap' + chapNum + '.pdf' } //document.location="" } } } xhr.open('POST', urlSite + '/compil_chap.php', false); xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); xhr.send("chap=" + chapNum); } function displayPdfTools(bol) { var liste = ['downloadPdf ', 'zoomPdf']; for (var i = 0; i < liste.length; i++) { var elt = document.querySelector('#' + liste[i]); if (bol) { elt.style.display = "block" } else { elt.style.display = "none" } } } function lienAccueil(bol) { console.log("lienAccueil " + bol) var elt = document.querySelector('#lienAccueil'); if (bol) { elt.style.display = "block" } else { elt.style.display = "none" } } function affPresentation() { document.querySelector('#aff').innerHTML = `

ChingInfo.fr

Le site ChingInfo rassemble le travail de 8 ans d'enseignement en ISN, ICN, NSI et d'ateliers informatiques.

N'hésitez pas à proposer des améliorations à ces exercices via l'adresse castanet@chingatome.fr

Quelques projets liés à l'enseignement de l'informatique: `; }var sacAdos_liste=[] function chap_sacAdosAdd(ev){ console.log("chap_sacAdosAdd "+sacAdos_liste.length+" "+sacAdos_liste) var elt = ev.currentTarget; var num = elt.getAttribute('num'); //Ajoute ou enlève l'exercice du sac à dos if((pos=sacAdos_liste.indexOf(num))!==-1){ console.log("aaaaaaaaa "+pos) sacAdos_liste.splice(pos,1) } else{ sacAdos_liste.push(num) } //Affiche le cadre rouge if(sac_isExoSelect(num)){ elt.style.backgroundColor="red"; } else{ elt.style.backgroundColor="transparent"; } //Actualise le compteur sac_actualiseCompteur() } function sac_isExoSelect(num){ console.log("sac_isExoSelect "+num); if(sacAdos_liste.indexOf(num)!=-1){ return true; } else{ return false; } } function sac_actualiseCompteur(){ console.log("sac_actualise"); //Mise à jour du numéro d'exercice var compteur = document.querySelector("#navigation > :nth-child(16) > :nth-child(2)"); if((num=sacAdos_liste.length) == 0){ compteur.innerHTML=''; compteur.style.display="none" } else{ compteur.innerHTML=num; compteur.style.display="block" } console.log(compteur+" "+num); } function sacAdos_aff(){ console.log("sacAdos_aff "+sacAdos_liste.length) //Envoi la compilation var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function() { if (this.readyState == 4){ if (xhr.status === 200) { //Affiche la compilation console.log(xhr.responseText); if(xhr.responseText.substring(0,7)=="Erreur:"){ diagMessage(xhr.responseText); return; } pdfChap.preparePdf(); pdfChap.chargePdf(urlSite+'/resultat/compilation/'+xhr.responseText+'.b64'); pdfChap.scrollY=0; pdfDownload = '/resultat/compilation/'+xhr.responseText+'.pdf'; //document.location="" } } } xhr.open('POST', urlSite+'/compil_sacAdos.php', false); xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); xhr.send("l="+sacAdos_liste.join(",")); //Ferme les autres fenêtres nav_fermeChap() document.querySelector("#affExo").style.display="none" }class mpdf { constructor(idContain, isMobile) { console.log("constructor " + isMobile); //==== Existence du div if (document.getElementById(idContain) == null) return; //=== Entregistre valeur this.idContain = idContain this.isMobile = isMobile; //===== Variable if (isMobile) { this.col = 1; } else { this.col = 2; } this.navPlus = null; this.url = null; this.loadRapide = true; this.pdfDocDoc = null; this.loadRapide = true; this.mobile = false; this.scrollDelta = 0; this.scrollY = null; this.scrollYmin = 0; this.scrollYmax = 0; this.scrollYContinous = 0; this.barreScroll = null; this.maxContain = 3 this.bScrollBody = false; this.bLiftScroll = false; this.liftScroll = null; this.boutonScrollActive = false; this.scrollOff = false; this.bMouseScroll = false; this.chargeClone = false; this.pageNumNext = 0 this.pageLoaded = []; this.renderWait = false; this.heightPdfTotal = 0; this.liftScrollCoeff = 0 this.renderAll = false this.navFirefox = false; this.zoomStrict = false; this.zoomStrictSuper = false; this.idResize = null; this.navPlusHeight = 0; this.vignette = false; this.callBackAfterCharge = null; this.titre = ""; this.enonceDate = null; this.correctionDate = null; this.exoPublie = null; this.timezone = null; this.touchMoveY = null; this.mouseMoveY = null; this.continueMoveY = [0, 0, 0, 0]; this.lastWheel = 0; this.loadTask; this.counterdown = "" } mySelector(x) { //console.log('#' + this.idContain + ' ' + x); return document.querySelector('#' + this.idContain + ' ' + x); } mySelectorAll(x) { return document.querySelectorAll('#' + this.idContain + ' ' + x); } preparePdf() { console.log("preparePdf " + this); this.timeDebut = Date.now(); this.divContain = document.getElementById(this.idContain); //console.log("aaaaaaaa " + this.divContain); //===== Efface le div var range = document.createRange(); range.selectNodeContents(this.divContain); range.deleteContents(); //this.divContain.innerHTML=""; //===== Vérifie l'existence des contains this.maxContain = (this.chargeClone ? 3 : 1); var contain = []; for (var i = 0; i < this.maxContain; i++) { //pdfContain var idContain = 'pdfContain' + i; var holder; if (this.mySelector('#' + idContain) == null) { contain[i] = document.createElement("div"); contain[i].id = idContain; contain[i].style.position = "relative" contain[i].style.alignSelf = "start" } else { contain[i] = this.mySelector('#' + idContain); } //Place à prendre if (i < this.col) { contain[i].style.display = "block"; contain[i].style.flex = "1"; } else { //contain.style.display="none"; contain[i].style.flex = "0"; } } //=====Ajoute la barre de séparation var barre = []; for (var i = 0; i < 2; i++) { barre[i] = document.createElement("div"); //barre.style.position = "absolute"; barre[i].style.width = "1px"; barre[i].style.height = "100%"; barre[i].style.left = ((i + 1) * 100 / this.col) + "%"; barre[i].style.backgroundColor = "black"; barre[i].style.zIndex = "10"; barre[i].id = "barreVertical" + i; } //====== Ajoute tout le monde this.divContain.appendChild(contain[0]); if(this.maxContain>1){ this.divContain.appendChild(barre[0]); this.divContain.appendChild(contain[1]); } if(this.maxContain>2){ this.divContain.appendChild(barre[1]); this.divContain.appendChild(contain[2]); } //=== gestion des paramètre this.pdfContain0 = this.mySelector("#pdfContain0") this.pdfContain1 = this.mySelector("#pdfContain1") this.pdfContain2 = this.mySelector("#pdfContain2") //===== Formatage du div if (!this.vignette) { //this.divContain.style.position="relative"; //this.divContain.style.flex="1"; this.divContain.style.display = "flex"; } this.divContain.style.overflow = "hidden"; this.divContain.style.margin = "0px auto"; //===== Evenement du div //lié à la souris var scope = this this.eventA = this.eventB = (e) => { this.scrollTouchStop(e); } this.eventC = (e) => { this.resizeWindow(e); } this.eventD = (e) => { this.scrollKey(e); } this.divContain.addEventListener("mousedown", (e) => { this.scrollMouseDown(e); }, { passive: false }); this.divContain.addEventListener("mouseleave", (e) => { this.scrollMouseOut(e); }, false); this.divContain.addEventListener("mouseup", (e) => { this.scrollMouseUp(e); }), { passive: false }; this.divContain.addEventListener("mousemove", (e) => { this.scrollMouseMove(e); }, { passive: false }); this.divContain.addEventListener("wheel", (e) => { this.scrollWheel(e); }, { passive: false }); //lié au toucher this.divContain.addEventListener("touchstart", (e) => { this.scrollTouchStart(e); }, { passive: false }); this.divContain.addEventListener("touchmove", (e) => { this.scrollTouchMove(e); }, { passive: false }); this.divContain.addEventListener("touchend", (e) => { this.scrollTouchEnd(e); }, { passive: false }); //lié à la fenêtre window.addEventListener("resize", this.eventC, { passive: false }); //lié aux touche document.addEventListener('keydown', this.eventD, false, { passive: false }); } /*======== ================== ============== ============== */ scrollMove(mvt, coef) { if (mvt != 0) { //console.log("scrollinfo "+mvt+" "+this.scrollDelta+" "+this.heightPdf); //Continuite defilement : pas pour wheel this.continueMoveY.push(mvt * coef); this.continueMoveY = this.continueMoveY.slice(-4); this.changeScroll(-mvt); } } scrollMouseDown(ev) { console.log("ooooooooooo 1"); this.bMouseScroll = true; this.mouseMoveY = ev.clientY; this.continueMoveY = [0, 0, 0, 0]; this.scrollYContinous = 0; } scrollMouseOut(ev) { console.log("ooooooooooo 2 "); this.bMouseScroll = false; this.bLiftScroll = false; } scrollMouseUp(ev) { console.log("ooooooooooo 3"); this.bMouseScroll = false; this.bLiftScroll = false this.scrollContinue(1); } scrollMouseMove(ev) { if (this.bMouseScroll) { var mvt = 0; mvt = this.mouseMoveY - ev.clientY; this.mouseMoveY = ev.clientY; //console.log("ooooooooooo 33"+mvt); // Scroll this.scrollMove(mvt, 1); } if (this.bLiftScroll) { //console.log("ooooooooooo 34"); this.scrollY -= ev.movementY / this.liftScrollCoeff; //console.log("ooooooooooopppppppppppppp "+this.liftScrollCoeff); this.updateScroll() } } scrollWheel(ev) { //this.actualiseAffichage() //console.log("wheel ............"+ev.deltaY+" "+ev.detail); var mvt; if (ev.deltaY < 0) mvt = -100; else mvt = 100; mvt = Math.max(-1, Math.min(1, ev.deltaY)) * 25 if (this.lastWheel + 40 < Date.now()) { //console.log("zzzz") if (this.lastWheel + 400 > Date.now()) { mvt = mvt * 4 } this.lastWheel = Date.now() } else { mvt = 0 } this.changeScroll(-mvt); } scrollTouchStart(ev) { //ev.preventDefault(); //ev.stopPropagation(); console.log("ooooooooooo 4"); this.touchMoveY = ev.touches[0].clientY; this.continueMoveY = [0, 0, 0, 0]; this.scrollYContinous = 0; } scrollTouchMove(ev) { ev.preventDefault(); ev.stopPropagation(); var mvt = this.touchMoveY - ev.touches[0].clientY; this.touchMoveY = ev.touches[0].clientY; this.scrollMove(mvt, 6); } scrollTouchEnd(ev) { console.log("ooooooooooo 6"); this.scrollMouseUp(ev) } scrollLiftDown(ev) { console.log("ll"); this.bLiftScroll = true; ev.preventDefault(); ev.stopPropagation(); } scrollKey(ev) { console.log("xxxxxxxxH " + this.divContain) if (this.scrollOff) return; console.log('scrollKey ' + ev.keyCode + ' ' + this.heightContaint); switch (ev.keyCode) { case 33: this.changeScroll(this.heightContaint); break; case 34: this.changeScroll(-this.heightContaint); break; case 38: this.changeScroll(40); break; case 40: this.changeScroll(-40); break; } } /*======== ================== ============== ============== */ resizeWindow() { console.log("resizeWindow"); if (this.idResize != null) { clearTimeout(this.idResize); } this.miseAjourParametre(); this.idResize = setTimeout((e) => { this.updateScroll(); this.annotationsPosition(e); }, 500); } miseAjourParametre() { console.log("miseAjourParametre()") this.heightContaint = parseInt(this.divContain.offsetHeight) this.heightPdf = parseInt(this.pdfContain0.offsetHeight); this.heightPdfTotal = this.heightPdf / (this.pageNumNext - 1) * this.pdfNumPages; //==== //==== Scroll //Definition de certaines constantes pour le scroll if (this.zoomStrict) { console.log("zoomStrict heightContaint:" + this.heightContaint + " heightPdf:" + this.heightPdf); //Ne permet pas au pdf de déborder if (this.heightContaint * this.col > this.heightPdf) { //Pdf plus petit que page console.log("pdf plus petite que la page " + this.heightContaint + " " + this.heightPdf + " " + this.col); this.scrollYmin = 0 this.scrollYmax = this.heightContaint * this.col - this.heightPdf; if (this.zoomStrictSuper) { this.scrollYmin = 0; } } else { this.scrollYmin = this.heightContaint * this.col - this.heightPdf; this.scrollYmax = 0; console.log("pdf plus grand que la page " + this.heightContaint + " " + this.heightPdf + " " + this.col + " " + this.scrollYmin + " " + this.scrollYmax); } } else { console.log("????????") this.scrollYmin = -this.heightContaint / this.heightPdf * this.col + 20 / this.heightPdf; this.scrollYmax = 1 - 20 / this.heightPdf; } if (this.scrollYmin == 0) { this.liftScrollCoeff = 0; } else { this.liftScrollCoeff = (this.heightContaint - 25) / (this.scrollYmin); } this.updateScroll(); //console.log("eee a " + this.heightContaint + " " + this.heightPdf + " " + this.scrollYmin + " " + this.scrollYmax + " " + this.col+" "+this.liftScrollCoeff) } /*======== ================== ============== ============== xxxxxxx */ chargeNextPage() { console.log("chargeNextPage "+this.pageNumNext+" "+this.pdfNumPages+" "+this.renderWait+" "+this.pageLoaded) if ((this.pageNumNext <= this.pdfNumPages) && (!this.renderWait)) { console.log("chargeNextPage A") if (this.pageLoaded.indexOf(this.pageNumNext) != false) { console.log("chargeNextPage B") this.renderWait = true this.pageLoaded.push(this.pageNumNext) this.pdfDocDoc.getPage(this.pageNumNext).then((resolve, reject) => { this.renderPage(resolve); }); } } } updateScroll() { //Verifie si le scroll est bloque console.log("updateScroll " + this.divContain +" "+this.scrollY + " " + this.scrollYmin) if (this.scrollOff) return; //Gère le scroll min et max if (this.scrollY <= this.scrollYmin) { this.scrollY = this.scrollYmin this.chargeNextPage() } if (this.scrollY > this.scrollYmax) { this.scrollY = this.scrollYmax; } //Gère l'affichage d'un bout de page manquant if(-scrollY+this.heightPdf 1) { this.pdfContain1.style.top = (this.scrollY - this.heightContaint) + "px"; //console.log("eeee bbbb "+this.scrollY+" "+this.heightContaint+" "+this.pdfContain1.style.top) } if (this.col > 2) { this.pdfContain2.style.top = (this.scrollY - 2 * this.heightContaint) + "px"; } //Affichage de navPlus if (this.navPlus != null) { if (this.scrollY == 0) { if (parseInt(this.navPlus.style.height) == 0) { requestAnimationFrame(() => { this.navPlus.style.height = '0px'; this.navPlus.style.transition = ''; requestAnimationFrame(() => { this.navPlus.style.height = this.navPlusHeight + 'px'; this.navPlus.style.transition = 'height 0.3s ease-out'; }); }); } } else { if (parseInt(this.navPlus.style.height) != 0) { requestAnimationFrame(() => { this.navPlus.style.height = this.navPlusHeight + 'px'; this.navPlus.style.transition = ''; requestAnimationFrame(() => { this.navPlus.style.transition = 'height 0.3s ease-out'; }); }); } } } if (Math.abs(this.scrollYContinous) > 1) { //console.log("scrollYContinous "+this.scrollYContinous); this.scrollYContinous = 0.9 * this.scrollYContinous; setTimeout(() => { this.changeScroll(this.scrollYContinous) }, 10); } //Actualise la position de l'ascenseur / lift //console.log("ffffffff "+ ((this.heightPdf - this.scrollY) / this.heightPdf)); this.liftScroll.style.top = (this.scrollY * this.liftScrollCoeff) + "px"; //Action différentiée pour le changement de scroll this.callbackScroll(); } callbackScroll() { } changeScrollPage(ev) { console.log("changeScrollPage B " + this.divContain) if (this.scrollOff) return; console.log("changeScrollPage"); var exoNum = ev.target.getAttribute("exercice"); this.scrollY = posExo[exoNum]; this.updateScroll(); } changeScroll(scrollAdd) { //console.log("changeScroll A "+this.divContain+" "+scrollAdd+" "+this.scrollDelta) if (this.scrollOff) return; //console.log("changeScroll B"); if (this.pdfContain0 == null) return; //console.log("changeScroll C"); this.scrollY = this.scrollY - scrollAdd * 2 * this.scrollDelta; this.scrollY += scrollAdd; //console.log("mpdfchangeScroll " + scrollAdd + " " + this.scrollY); this.updateScroll(); } scrollContinue(coef) { //console.log("scrollContinue D " + this.divContain) if (this.scrollOff) return; //Scroll continue var mean = (this.continueMoveY[0] + this.continueMoveY[1] + this.continueMoveY[2] + this.continueMoveY[3]) / 4; this.continueMoveY = [0, 0, 0, 0]; //console.log("eeeeeeeeeeeeeeee "+mean); if (Math.abs(mean) > 10) { console.log("scrollcontinue : " + this.continueMoveY + " " + mean); this.scrollYContinous = -coef * mean; this.changeScroll(0); } } //======================= annotationsSearch(pdfPage, div, viewport, scale) { console.log("annotationsSearch " + pdfPage + " " + div.id + " " + viewport + " " + scale) var result; pdfPage.getAnnotations().then((annotations) => { var view = pdfPage.view; div.setAttribute("viewWidth", pdfPage.view[2]); //console.log("a"+pdfPage.pageIndex); //console.log(annotations) for (var i = 0; i < annotations.length; i++) { //console.log("kkkkkkkkkkkkk " + annotations[i].url) var el = null; if (annotations[i].url == null) { el = document.createElement("div"); el.style.display = "inline-block"; el.className = "annotation" var commentaire = annotations[i]["contents"]; commentaire = commentaire.replace(/'/g, " "); for (var j = 0; j < 32; j++) { commentaire = commentaire.replace(String.fromCharCode(j), ""); } //Creation de l'action var re = /sacados\/([0-9]+)$/; var num = commentaire.match(re); if ((num != null) && (num.length == 2)) { //===Sac a dos el.className = "annotation global_lienSacAdos" //En rouge si déjà sélectionné var regexp = new RegExp('^[0-9]+-' + num[1] + '$'); for (var j = 0; j < window.exoSacAdos.length; j++) { if (regexp.test(window.exoSacAdos[j])) { el.style.backgroundColor = "red"; } } //Evenemennt el.setAttribute('num', num[1]); el.setAttribute("myClick", 'sacAdos'); } else { //==Siimp le commentaire var c = commentaire.replace(/\n/g, "
"); var c = c.replace(/\r/g, "
"); el.setAttribute("myClick", "diagMessage"); el.setAttribute("diagMessage", c); } } else { //Lien vers une page web var url = annotations[i].url; if ((result = /\/exercice\/([0-9]+)$/.exec(url)) != null) { //Ouvre un lien exercice dans chingatome url = url.replace('/exercice/', '/exo/'); el = document.createElement("span"); el.className = "annotation global_lienCorrection" el.setAttribute("alt", "correction " + result[1]) el.setAttribute("myClick", "affExoCorrec") el.setAttribute('numExo', result[1]); //el.setAttribute("href", url); //el.innerHTML="a" } else if ((result = /\/e([0-9]+)-([0-9]+)-([0-9]+)/.exec(url)) != null) { //Ouvre un lien exercice dans le sous domaine el = document.createElement("span"); el.className = "annotation global_lienCorrection" el.setAttribute("alt", "aff correction") el.setAttribute('p', result[1]); el.setAttribute('c', result[2]); el.setAttribute('e', result[3]); //el.setAttribute("href", url); el.setAttribute('myClick', 'sd_affCorrec'); } else if ((result = /\/q([0-9]+)-([0-9]+)-([0-9]+)/.exec(url)) != null) { //Ouvre un lien exercice dans le sous domaine el = document.createElement("span"); el.className = "annotation global_lienCorrection" el.setAttribute("alt", "aff correction") el.setAttribute('p', result[1]); el.setAttribute('c', result[2]); el.setAttribute('e', result[3]); //el.setAttribute("href", url); el.setAttribute('myClick', 'sd_qrcodeCorrec'); } else if ((result = /\/info-([0-9]+)-(.*)$/.exec(url)) != null) { //Ouvre un lien exercice dans le sous domaine el = document.createElement("span"); el.className = "annotation global_lienInfo" el.setAttribute('n', result[1]); el.setAttribute('f', result[2]); //el.setAttribute("href", url); el.setAttribute('myClick', 'info_lien'); } else { if ((result = /signalezErreur-([0-9]+)$/.exec(url)) != null) { el = document.createElement("span"); el.className = "annotation" //Ouvre la boite à dialogue pour signaler erreur el.setAttribute('numExo', result[1]); el.setAttribute('myclick', 'ex_mailBlock'); } else { el = document.createElement("a"); el.className = "annotation" el.setAttribute("href", url); } } } el.setAttribute("target", "chingatome"); var r = annotations[i].rect; el.style.position = "absolute"; var rect = pdfjsLib.Util.normalizeRect([ r[0], view[3] - r[1] + view[1], r[2], view[3] - r[3] + view[1]]); el.setAttribute("annWidth", rect[2] - rect[0]); el.setAttribute("annHeight", rect[3] - rect[1]); el.setAttribute("annLeft", r[0]); el.setAttribute("annTop", 1 * r[3]); el.setAttribute("annId", div.id); //Nouveau el.setAttribute("annWidth", r[2] - r[0]); el.setAttribute("annHeight", r[3] - r[1]); el.setAttribute("annLeft", r[0]); el.setAttribute("annTop", view[3] - r[1]); el.setAttribute("annPdfWidth", view[2]); //Copie dans les colonnes if (this.chargeClone) { var listeHolder = [this.pdfContain0, this.pdfContain1, this.pdfContain2] for (var k = 1; k < 3; k++) { var eltClone = el.cloneNode(false) listeHolder[k].querySelector("#div" + pdfPage._pageIndex).appendChild(eltClone); } } /* var transform = viewport.transform; //var transformStr = 'matrix(' + transform.join(',') + ')'; //el.style.transform=transformStr; var transformOriginStr = -rect[0] + 'px ' + -rect[1] + 'px'; //el.style.transformOrigin=transformOriginStr; */ div.appendChild(el); } this.annotationsActive(pdfPage._pageIndex) this.annotationsPosition(pdfPage._pageIndex) }); } annotationsActive(numPage) { console.log("annotationsActive "+this.maxContain) var listeContain = [this.pdfContain0, this.pdfContain1, this.pdfContain2]; for (var j = 0; j < this.maxContain; j++) { var liste = listeContain[j].querySelectorAll("#div" + numPage + " .annotation"); for (var i = 0; i < liste.length; i++) { var result; if ((result = liste[i].getAttribute('myClick')) != null) { if (result == 'sd_affCorrec') { //Creation du lien liste[i].addEventListener('click', sd_affCorrec); //liste[i].addEventListener('touchstart',sd_affCorrec); } if (result == 'affExoCorrec') { liste[i].addEventListener('click', chap_affExoCorrec, true); } if (result == 'sd_qrcodeCorrec') { liste[i].addEventListener('click', sd_qrcodeCorrec, true); } if (result == 'sacAdos') { liste[i].addEventListener('click', chap_sacAdosAdd); } if (result == 'ex_mailBlock') { liste[i].addEventListener('click', ex_mailBlock); } if (result == "diagMessage") { const msg = liste[i].getAttribute('diagMessage') liste[i].addEventListener('click', () => { diagMessage(msg); }); } } } } } annotationsPosition(numPage) { console.log("annotationsPosition " + numPage); //scale=div.clientWidth/pdfPage.view[2]; //Repositionne chaque annotation var listeContain = [this.pdfContain0, this.pdfContain1, this.pdfContain2] for (var j = 0; j < this.maxContain; j++) { var liste = listeContain[j].querySelectorAll("#div" + numPage + " .annotation"); var liste = listeContain[j].querySelectorAll(".annotation"); var divVal = {}; //console.log("kkkkkkkkkkkkkkaaaaa " + liste.length); for (var i = 0; i < liste.length; i++) { var idDiv = liste[i].getAttribute("annId"); if (true || divVal[idDiv + "ViewWidth"] == undefined) { divVal[idDiv + "ViewWidth"] = this.mySelector('#' + idDiv).getAttribute("viewWidth"); divVal[idDiv + "ClientWidth"] = this.mySelector('#' + idDiv).clientWidth; divVal[idDiv + "ClientHeight"] = this.mySelector('#' + idDiv).clientHeight; divVal[idDiv + "Scale"] = divVal[idDiv + "ClientWidth"] / liste[i].getAttribute('annPdfWidth'); } //console.log(divVal) var scale = divVal[idDiv + "Scale"]; var myClick = liste[i].getAttribute('myclick'); if ((myClick == 'affExoCorrec') || (myClick == 'sacAdos') || (myClick == 'sd_affCorrec')) { var zoom = 1.4; } else { var zoom = 1; } var w = liste[i].getAttribute("annWidth") * scale; var h = liste[i].getAttribute("annHeight") * scale; liste[i].style.width = (w * zoom) + "px"; liste[i].style.height = (h * zoom) + "px"; //console.log("Taille annotation : "+liste[i].getAttribute("annWidth")+" "+liste[i].style.height); liste[i].style.left = (liste[i].getAttribute("annLeft") * scale - w * ((zoom - 1) / 2)) + "px"; liste[i].style.top = (divVal[idDiv + "ClientHeight"] - liste[i].getAttribute("annTop") * scale - h * ((zoom - 1) / 2)) + "px"; liste[i].style.top = (liste[i].getAttribute("annTop") * scale - h) + "px"; //Nouveau var w = liste[i].getAttribute("annWidth") * scale; //liste[i].style.top = liste[i].getAttribute('annTop') * divVal[idDiv + "Scale"] - h - h * ((zoom - 1) / 2); } } //Extra parametre if (this.callBackAfterCharge != null) { this.callBackAfterCharge(); } } //======================= chargeInfoExercice() { console.log("chargeInfoExercice"); var xhr = new XMLHttpRequest(); xhr.responseType = 'json'; xhr.onreadystatechange = function () { if (xhr.readyState == 4) { if (xhr.status == 200) { //Efface toutes les images si nécessaires var myNode = this.mySelector('#domNavExo'); if (myNode !== null) { while (myNode.firstChild) { myNode.removeChild(myNode.firstChild); } el = myNode.nextSibling; } //Crée les nouvelles images a = xhr.response; for (var b in a) { if (a.hasOwnProperty(b)) { var img = document.createElement("img"); img.src = racineUrl + "/image/sousDomaine/nombre" + b + ".png"; console.log("A VERIFIER L UTILITE DE CE CODE") img.style.width = "30px"; img.style.marginLeft = "30px"; img.style.cursor = "pointer"; img.setAttribute("exercice", b); img.addEventListener("click", (e) => { this.changeScrollPage(e); }); posExo[b] = a[b]; myNode.appendChild(img); } } } else { document.title = "Error code " + xhr.status; } } } xhr.open("GET", racineUrl + "/sousDomaineAffExo-scroll.php?p=" + getProf + "&f=" + getFeuille + "&t=" + getType); xhr.send(null); } chargePdf(url,cache=false) { console.log("chargePdf " + url + " " + this.col + " " + this.maxContain); this.url = url; this.pageLoaded = [] //=== Vide tous les holders var liste = [this.pdfContain0, this.pdfContain1, this.pdfContain2]; for (var i = 0; i < this.maxContain; i++) { var myNode = liste[i]; if (myNode == null) continue; var range = document.createRange(); range.selectNodeContents(myNode); range.deleteContents(); } //=== Ajoute la barre du scroll if (this.mySelector('#myPdfLiftScroll') == null) { //console.log("aaaaaaaa " + this.isMobile) this.barreScroll = document.createElement("div"); this.barreScroll.id = "myPdfBarreScroll"; this.divContain.appendChild(this.barreScroll); this.liftScroll = document.createElement("div"); this.liftScroll.id = "myPdfLiftScroll"; this.liftScroll.style.top = "0px"; this.barreScroll.appendChild(this.liftScroll); this.liftScroll.addEventListener("mousedown", (e) => { this.scrollLiftDown(e) }); } //==== Ajoute le counterdown if (false) { var elt = document.createElement('div'); elt.id = "counterdownDiv_" + this.counterdown; elt.className = "myPdf_counterdownDiv" elt.style.display = "none" elt.innerHTML = ''; this.divContain.appendChild(elt) } //=== Chargement du nouveau PDF if (this.scrollY === null) { this.scrollY = 0; } //=== charge le pdf var xhr = new XMLHttpRequest(); var scope = this; pdfjsLib.GlobalWorkerOptions.workerSrc = urlSite + "/pdfjs-" + versionPdf + "/pdf.worker.js" xhr.onreadystatechange = () => { if (xhr.readyState == 4) { if (xhr.status == 200) { console.log("chargePdf - fin " + xhr); //==== Rattrape des headers pour suite du java var tmp = xhr.getResponseHeader('myPdf-enonccommenteDate'); if (tmp != null) scope.enonceDate = tmp tmp = xhr.getResponseHeader('myPdf-correctionDate'); if (tmp != null) scope.correctionDate = tmp tmp = xhr.getResponseHeader('myPdf-exoPublie'); if (tmp != null) scope.exoPubliee = tmp tmp = xhr.getResponseHeader('myPdf-timezone'); if (tmp != null) scope.timezone = tmp //console.log('enonceDate:' + scope.enonceDate + " correctionDate" + scope.correctionDate); //==== Chargement du pdf if (xhr.responseText.substring(0, 4) == "MSG:") { console.log("Gestion message erreur"); diagMessage(xhr.responseText.substring(4)); scope.loadTask = pdfjsLib.getDocument('/image/sousDomaine/accueil-orig.pdf'); } else if (xhr.responseText.substring(0, 7) == "Erreur:") { this.divContain.innerHTML = xhr.responseText.substring(7) return; } else { var myData; try{ myData = atob(xhr.responseText) } catch(error){ setTimeout(() => {scope.chargePdf(url,true)},4000); console.log(error) return; } scope.loadTask = pdfjsLib.getDocument({ data: myData, disableFontFace: false, disableRange: true, disableStream: true, disableAutoFetch: true }); } scope.loadTask.promise.then((resolve, reject) => { scope.pdfLoad(resolve); })//.catch(scope.errorPdf); } } }; //rajoute le drapeau b64 //url = url + (url.indexOf('?') == -1 ? "?" : "&") + 'b64=1&error-cache=1'; if(cache){ url = url + (url.indexOf('?') == -1 ? "?" : "&") + 'error=yes'; } console.log("chargePdf - url - " + url) //Ouverture xhr.open("GET", url, true); if(cache){ xhr.setRequestHeader('Cache-Control', 'no-cache'); } xhr.send(); //console.log("aaaaaaaaaa "+this.url); //var loadTask = pdfjsLib.getDocument({url:this.url,disableFontFace:true}); } errorPdf(error) { console.log("errorPdf") window.alert("Erreur de chargement du fichier pdf.\nContactez l'administrateur du site " + error); } pdfLoad(pdfDoc) { console.log('pdfDoc ' + this); console.log('pdfDoc ' + this + " " + this.enonceDate); /* NE PAS EFFACER - A GARDER pdfDoc.getMetadata().then(function(stuff) { if(stuff.info != null){ this.titre=stuff.info.Title; this.keywords=stuff.info.Keywords }}); */ //== Ouvre le countdown if (false && this.counterdown != "") { document.querySelector('#counterdownDiv_' + this.counterdown).style.display = 'block'; } //console.log("eeeeeeeeeeee yyyyyyy"+pdfDoc.getMetadata(); //S'éxécute asynchrone lors fin téléchargement. console.log("pdfLoad " + pdfDoc.numPages); this.pdfDocDoc = pdfDoc; //Efface toutes les pages pdf this.pagePdf = new Array(); this.pdfNumPages = pdfDoc.numPages; //Charge chaque page du pdf if (this.loadRapide) { pdfDoc.getPage(1).then((resolve, reject) => { this.renderPage(resolve); }); } else { for (var num = 1; num <= pdfDoc.numPages; num++) { pdfDoc.getPage(num).then(renderPage).catch(errorRenderPage); } } } errorRenderPage(error) { window.alert("Erreur: " + error); } renderPage(page) { //if(page.pageIndex!=1) return; var numPage = page._pageIndex; console.log("renderPage " + page + " " + numPage); //Charge la page suivante this.pageNumNext = parseInt(page._pageIndex) + 2; //S'éxécute de manière asynchrone après récupération d'une page /* if(pagePdf[page.pageIndex]==null){ pagePdf[page.pageIndex]=page; } */ //==== Chargement containPdf0 var idDiv = "div" + numPage; if (this.mySelector('#' + idDiv) == null) { var div = document.createElement('div'); div.id = idDiv; div.style.position = "relative"; //div.style.width="50%" this.pdfContain0.appendChild(div); } var eltCanvas = this.mySelector('#canvas-' + numPage); if (eltCanvas == null) { //Crée le conteneur eltCanvas = document.createElement('canvas'); eltCanvas.id = 'canvas-' + numPage; eltCanvas.style.width = "100%"; this.mySelector('#' + idDiv).appendChild(eltCanvas); //Ajoute trait entre page var trait = document.createElement('div'); if (this.col == 1) { trait.className = "myPdfSeparation"; } else { trait.className = "myPdfTrait"; } this.pdfContain0.appendChild(trait); } //==== Charge le pdf dans le premier canevas div = this.mySelector("#div" + numPage); var viewport = page.getViewport({ scale: 1 }); // Autre //var scale=canvas.width/viewport.width*0.9; var scale = document.body.clientWidth / viewport.width * 1.5; //Prend body car div pas chargé pour 1er page/pdf if (scale < 1.8) scale = 1.8; if (scale > 2.5) scale = 2.5; var viewport = page.getViewport({ scale: scale }); var ctx = eltCanvas.getContext('2d'); eltCanvas.width = viewport.width; eltCanvas.height = viewport.height; console.log("bbbbbbb " + eltCanvas.height) var renderContext = { canvasContext: ctx, viewport: viewport, enableWebGl: true }; var renderTask = page.render(renderContext); renderTask.promise.then( () => { console.log("RenderTask " + page._pageIndex + " : " + (Date.now() - this.timeDebut) + "s"); //Fin de chargement de la page var canvasOld = this.mySelector('#canvas-' + page._pageIndex); var div = this.mySelector('#div' + page._pageIndex); if (div == null) return; //Copie dans le cas de l'affichage multi-colonne if (this.chargeClone) { //console.log("mmmmmmmddddddddd "+page._pageIndex+" "+canvasOld+" "+div); var liste = [this.pdfContain0, this.pdfContain1, this.pdfContain2] for (var i = 1; i < 3; i++) { //console.log(i) var clone = div.cloneNode(true); var can = clone.firstChild; //console.log(can) can.getContext('2d').drawImage(canvasOld, 0, 0); liste[i].appendChild(clone); } } //Actualise les dimensions du pdf this.renderWait = false; this.miseAjourParametre(); this.updateScroll(); //Affiche les annotations / liens this.annotationsSearch(page, div, viewport, scale); //=== Première page : /* if (page._pageIndex == 0) { //Fonctionne que pour la 1er page : décalage style.top if (this.chargeClone) { var decal = parseInt(this.mySelector('#pdfContain0').clientHeight); console.log("mmmmmmmm"); //this.pdfContain1.style.top = "-" + decal + "px"; this.pdfContain2.style.top = "-" + (2 * decal) + "px" } } */ //RenderAll if (this.renderAll) { if (this.pageNumNext - 1 != this.pdfNumPages) { this.renderWait = true this.pageLoaded.push(mpdfPrinc.pageNumNext) this.pdfDocDoc.getPage(mpdfPrinc.pageNumNext).then((resolve, reject) => { mpdfPrinc.renderPage(resolve); }); } else { this.scrollY = -this.renderAll * mpdfPrinc.heightPdfTotal; this.updateScroll(); } } return; if (this.loadRapide) { //console.log('fffffffff'+page._pageIndex+" "+(this.pdfDocDoc)); if (page._pageIndex < this.pdfDocDoc.numPages - 1) { console.log("Lit la prochaine page " + page._pageIndex); //pdfDocDoc.getPage(2).then(renderPage); this.pdfDocDoc.getPage(parseInt(page._pageIndex) + 2) .then((resolve, reject) => { this.renderPage(resolve); }); } } //Verifie la fin du chargement this.pdfNumPages--; //document.title+=" - "+pdfNumPages+" "+page.pageIndex; this.heightContaint = this.mySelector('#pdfContain0').offsetHeight; if (this.pdfNumPages == 0) { console.log("Durée chargement pdf : " + (Date.now() - this.timeDebut)); console.log("RenderTask Fin"); //Fin de chargement de toutes les pages this.actualiseAffichage(); this.changeScroll(this.scrollY);//xxxxxxxxxx this.activeAnnotations(); //Actualise les dimensions du pdf this.heightPdf = this.mySelector('#pdfContain0').offsetHeight; console.log("Durée chargement pdf : " + (Date.now() - this.timeDebut)); //Femer le countdown if (this.countdown != "") { var elt = document.getElementById('counterdownDiv_' + this.counterdown) elt.style.display = "none"; var elt = document.getElementById('counter_down_' + this.counterdown) elt.style.animation = "none"; } //Extra parametre if (this.callBackAfterCharge != null) { this.callBackAfterCharge(); } } else { //Page intermédiaire } } ); } actualiseAffichage() { console.log("actualiseAffichage " + this.col + " " + (this.bActualisePdf ? "oui" : "non")); for (var i = 0; i < this.maxContain; i++) { if (i < this.col) { this.mySelector('#pdfContain' + i).style.flex = "1"; } else { this.mySelector('#pdfContain' + i).style.flex = "0"; } /* document.getElementById("pdfContain"+i).style.width=(100/this.col)+"%"; document.getElementById("pdfContain"+i).style.left=(i*100/this.col)+"%"; */ } //Gestion des barres de séparation var barreVertical0 = this.mySelector('#barreVertical0').style; var barreVertical1 = this.mySelector('#barreVertical1').style; switch (this.col) { case 1: barreVertical0.left = "120%"; barreVertical1.left = "120%"; break; case 2: barreVertical0.left = "50%"; barreVertical1.left = "120%"; break; case 3: barreVertical0.left = "33.3333%"; barreVertical1.left = "66.6666%"; break; } /* //Render des pdf for(j=0;j { diagMessage(msg); }); } } else{ if(liste[i].getAttribute('target')!=null){ liste[i].className="annotation lienExterne" } } } } } }