From a7db32ec6f9775fe4fc9ae2a348b9d100a9dd6cf Mon Sep 17 00:00:00 2001 From: xdrm-brackets Date: Fri, 21 Oct 2016 15:19:32 +0200 Subject: [PATCH] =?UTF-8?q?Calcul=20du=20hash=20lors=20du=20`storageToFiel?= =?UTF-8?q?ds`=20car=20c'est=20la=20qu'on=20verra=20s'il=20y=20a=20de=20"r?= =?UTF-8?q?=C3=A9elles"=20modifications=20par=20l'utilisateur=20+=20V?= =?UTF-8?q?=C3=A9rification=20du=20hash=20lors=20de=20`fieldsToStorage`=20?= =?UTF-8?q?[FICHES+MINI-FICHES]=20+=20d=C3=A9sactivation=20de=20la=20gesti?= =?UTF-8?q?on=20du=20clonage=20qui=20bug?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- public_html/js/includes/input-phone-fiche.js | 23 +-- public_html/js/includes/input-phone-mini.js | 182 +++++++----------- .../js/includes/min/input-phone-fiche.js | 35 ++-- .../js/includes/min/input-phone-mini.js | 26 +-- 4 files changed, 110 insertions(+), 156 deletions(-) diff --git a/public_html/js/includes/input-phone-fiche.js b/public_html/js/includes/input-phone-fiche.js index 110cf62..767e821 100644 --- a/public_html/js/includes/input-phone-fiche.js +++ b/public_html/js/includes/input-phone-fiche.js @@ -65,8 +65,6 @@ inputPhoneFiche.prototype.fieldsToStorage = function(){ /* (4) On récupère et met en forme les valeurs du deflater */ obj = { - contact: parseInt(deflated.contact), - uid: parseInt(deflated.uid), sexe: deflated.sexe, age: deflated.age, job: deflated.job, @@ -83,7 +81,9 @@ inputPhoneFiche.prototype.fieldsToStorage = function(){ contextSpecial: deflated.contextSpecial, freq: deflated.freq, connect: deflated.connect, - connectSpecial: deflated.connectSpecial + connectSpecial: deflated.connectSpecial, + uid: parseInt(deflated.uid), + contact: parseInt(deflated.contact) }; /* (5) On calcule/compare le hash */ @@ -92,7 +92,7 @@ inputPhoneFiche.prototype.fieldsToStorage = function(){ hash = crc32( JSON.stringify(obj) ); // {5.2} Si le hash est identique, on ne fait rien // - if( existingData != null && existingData.hash != null && hash == existingData.hash ) + if( existingData['hash'] != undefined && hash == existingData.hash ) continue; // {5.3} On enregistre le hash // @@ -104,7 +104,7 @@ inputPhoneFiche.prototype.fieldsToStorage = function(){ /* (7) On met à jour le `timestamp` (car à ce point, on a une modification) */ obj.timestamp = Date.now(); - console.warn('> FICHE UPDATE ('+(obj.timestamp-input_ts)+')'); + console.warn('> FICHE UPDATE ('+(obj.timestamp-input_ts)+')', existingData, obj); /* (8) On enregistre les données dans le 'localStorage' */ lsi.set('p_fiches', obj.uid, obj); @@ -318,9 +318,7 @@ inputPhoneFiche.prototype.storageToFields = function(){ /* (3) Pour chaque fiche */ for( var key in ficheData ){ - // {3.1} Pour toutes les fiches // - - // On enregistre le hash (sans `timestamp`, `hash`, `valid`) + // {3.1} On calcule/enregistre le hash (sans `timestamp`, `hash`, `valid`) // clone = cloneObject( ficheData[key] ); delete clone['hash']; delete clone['timestamp']; @@ -331,16 +329,13 @@ inputPhoneFiche.prototype.storageToFields = function(){ lsi.set('p_fiches', ficheData[key].uid, ficheData[key]); // {3.2} Pour la fiche à rendre graphiquement // - if( ficheData[key].uid == this.selected ){ - + if( ficheData[key].uid == this.selected ) this.add(ficheData[key]); - } - } - // {4} On met à jour la navigation // + /* (4) On met à jour la navigation */ this.updateNavBar(); @@ -403,7 +398,7 @@ inputPhoneFiche.prototype.sync = function(){ } - { /* (3) Gestion des liens entre mini-fiches et fiches + if( false ){ /* (3) Gestion des liens entre mini-fiches et fiches ---------------------------------------------------------*/ var originalContact, cloneContact, hasSameUsername, hasSameLink, diff --git a/public_html/js/includes/input-phone-mini.js b/public_html/js/includes/input-phone-mini.js index eba9b6f..57a5116 100644 --- a/public_html/js/includes/input-phone-mini.js +++ b/public_html/js/includes/input-phone-mini.js @@ -5,6 +5,7 @@ function inputPhoneMini(container, navContainer){ this.nav_container = navContainer; } + /* [1] Attributs =========================================================*/ inputPhoneMini.prototype = { @@ -32,75 +33,60 @@ inputPhoneMini.prototype = { inputPhoneMini.prototype.fieldsToStorage = function(){ console.group('[phone.mini] fields to storage'); - // {1} Pour chaque formulaire de MINI fiche à l'écran // + var i, l, deflater, deflated, existingData, obj, hash; + + /* (1) Pour chaque formulaire de MINI fiche à l'écran + ---------------------------------------------------------*/ var existingMiniFiches = $$('[data-sublink="phone"] article.mini-relation-panel .mini-fiche-relation'); - for( var i = 0 ; i < existingMiniFiches.length ; i++ ){ - // {2} On initialise notre deflater pour récupérer les valeurs // - var deflater = new FormDeflater(existingMiniFiches[i], ['input', 'select'], ['data-name']); + for( i = 0, l = existingMiniFiches.length ; i < l ; i++ ){ - // {3} On enregistre ce contact si le numéro n'est pas vide et soit pseudo/prénom/nom // - var deflated = deflater.deflate(); - // On crée le hash - var deflatedHash = crc32(JSON.stringify(deflated)); + /* (1) On initialise notre deflater pour récupérer les valeurs */ + deflater = new FormDeflater(existingMiniFiches[i], ['input', 'select'], ['data-name']); + /* (2) On récupère les données */ + deflated = deflater.deflate(); + /* (3) On récupère les données du LSI si elles existent */ + existingData = lsi.get('p_mini-fiches', deflated.uid); - - // {4} On récupère les données du LSI si elles existent // - var existingData = lsi.get('p_mini-fiches', deflated.uid); - - // Si n'existe pas, on passe à la suivante + // Si erreur, on passe à la fiche suivante if( existingData === false ) continue; - // {5} On récupère et met en forme les valeurs du deflater // - // Si le hash est le même, on ne fait rien - if( existingData != null && existingData.hash != null ) - if( existingData.hash === 0 ) - console.log('MINI#'+existingData.uid+' UPDATED BUT NO TIMESTAMP UPDATE'); - else if( existingData.hash == deflatedHash ) - return; - - - var obj = { - uid: parseInt(deflated.uid), + /* (4) On récupère et met en forme les valeurs du deflater */ + obj = { contact: parseInt(deflated.uid), - sexe: deflated.sexe, // [0] Homme, [1] Femme, [2] Indéterminé + sexe: deflated.sexe, age: deflated.age, studies: deflated.studies, - reltype: deflated.reltype, // [0] ... + loc: deflated.loc, + reltype: deflated.reltype, reltypeSpecial: deflated.reltypeSpecial, - loc: deflated.loc, // [0] Choix 1 -> [3] Choix 4 unknown: deflated.unknown != null, - hash: deflatedHash + uid: parseInt(deflated.uid) }; - /* (8) On vérifie la validité des données et on l'enregistre dans l'objet avec la date de modification */ - obj.valid = this.check(obj); + /* (5) On calcule/compare le hash */ - // On met à jour la date de modification, si on a pas qu'@uid de différent - // {8.1} Si on doit mettre à jour // - if( existingData.hash !== 0 ){ + // {5.1} On calcule le hash // + hash = crc32( JSON.stringify(obj) ); - // Si on a des modifications, on met à jour le `timestamp` // - if( diff(existingData, obj, ['hash', 'valid', 'timestamp']).length > 0 ){ - console.log( diff(existingData, obj, ['hash', 'valid', 'timestamp']) ); + // {5.2} Si le hash est identique, on ne fait rien // + if( existingData['hash'] != undefined && hash == existingData.hash ) + continue; - obj.timestamp = Date.now(); - console.warn('> MINI UPDATE ('+(obj.timestamp-input_ts)+')'); - - } - - if( existingData['timestamp'] == undefined || !isNaN(existingData.timestamp) ) - obj.timestamp = Date.now(); - - // {6.2} Initialisation du `timestamp` si pas encore fait // - }else if( existingData['timestamp'] == undefined || !isNaN(existingData.timestamp) ) - obj.timestamp = 0; + // {5.3} On enregistre le hash // + obj.hash = hash; - /* (9) On enregistre les données dans le 'localStorage' */ - console.warn('saving mini#'+obj.uid+' with timestamp of '+obj.timestam+' and hash of '+existingData.hash+' and now '+obj.hash); + /* (6) On calcule la validité des données */ + obj.valid = this.check(obj); + + /* (7) On met à jour le `timestamp` (car à ce point, on a une modification) */ + obj.timestamp = Date.now(); + console.warn('> MINI UPDATE ('+(obj.timestamp-input_ts)+')'); + + /* (8) On enregistre les données dans le 'localStorage' */ lsi.set('p_mini-fiches', obj.uid, obj); } @@ -110,13 +96,6 @@ inputPhoneMini.prototype.fieldsToStorage = function(){ }; - - - - - - - /* [3] Gestion de l'ajout physique d'un nouveau contact =========================================================*/ /* @@ -225,14 +204,6 @@ inputPhoneMini.prototype.add = function(objectData){ }; - - - - - - - - /* [4] Gestion de l'affichage depuis le 'localStorage' =========================================================*/ inputPhoneMini.prototype.storageToFields = function(){ @@ -240,44 +211,63 @@ inputPhoneMini.prototype.storageToFields = function(){ /* (1) On charge le contact selectionné ---------------------------------------------------------*/ - var miniData = lsi.get('p_mini-fiches', this.selected); + var miniData = lsi.export('p_mini-fiches'); + var miniKeys = lsi.keys('p_mini-fiches'); + var selectedMini = miniData[this.selected] != undefined ? miniData[this.selected] : null; - /* (2.1) Si on ne trouve pas + /* (2) Si aucune mini sélectionnée, on prend la première ---------------------------------------------------------*/ - if( miniData === null ){ + if( selectedMini === null ){ - /* (2.1.1) Si `selected` est pas encore défini + /* (2.1) Si `selected` n'est pas encore défini ---------------------------------------------------------*/ if( this.selected === null ){ - var k = lsi.keys('p_mini-fiches'); - - /* (1) S'il y a au moins 1 contact -> on le prend */ - if( k.length > 0 ){ - this.selected = k[0]; - return this.storageToFields(); - - /* (2) Sinon, on quitte */ - }else + /* (1) Si aucune mini, on quitte */ + if( miniKeys.length == 0 ) return false; + /* (2) Sinon, on prend la première */ + this.selected = miniKeys[0]; + return this.storageToFields(); - /* (2.1.2) S'il est déja défini, on met à jour la nav + /* (2.2) S'il est déja défini, on met à jour la nav ---------------------------------------------------------*/ }else{ this.updateNavBar(); return false; } + } - /* (2.2) Si on trouve + /* (3) Affichage de la fiche sélectionnée ---------------------------------------------------------*/ + var clone, hash; + /* (1) On réinitialise le HTML */ this.container.innerHTML = ''; - /* (2) On affiche la MINI fiche sélectionnée */ - this.add(miniData); + /* (2) Pour chaque mini */ + for( var key in miniData ){ + + // {3.1} On calcule/enregistre le hash (sans `timestamp`, `hash`, `valid`) // + clone = cloneObject( miniData[key] ); + delete clone['hash']; + delete clone['timestamp']; + delete clone['valid']; + miniData[key].hash = crc32( JSON.stringify(clone) ); + + // On enregistre dans le `localStorage` + lsi.set('p_fiches', miniData[key].uid, miniData[key]); + + // {2.2} Pour la fiche à rendre graphiquement // + if( miniData[key].uid == this.selected ) + this.add(miniData[key]); + + + } + /* (3) On met à jour la navigation */ this.updateNavBar(); @@ -287,15 +277,6 @@ inputPhoneMini.prototype.storageToFields = function(){ }; - - - - - - - - - /* [5] Synchronisation des CONTACT vers les MINI fiches =========================================================*/ inputPhoneMini.prototype.sync = function(){ @@ -353,19 +334,10 @@ inputPhoneMini.prototype.sync = function(){ } } - - - - - console.groupEnd(); + console.groupEnd(); }; - - - - - /* [6] Gestion de la navigation entre les fiches =========================================================*/ inputPhoneMini.prototype.nav = function(element){ @@ -387,11 +359,6 @@ inputPhoneMini.prototype.nav = function(element){ }; - - - - - /* [7] Mise à jour de la navigation =========================================================*/ inputPhoneMini.prototype.updateNavBar = function(){ @@ -437,8 +404,6 @@ inputPhoneMini.prototype.updateNavBar = function(){ }; - - /* [8] Vérification des données du formulaire =========================================================*/ inputPhoneMini.prototype.check = function(miniData){ @@ -472,9 +437,6 @@ inputPhoneMini.prototype.check = function(miniData){ }; - - - /* [9] Point d'amorçage de la gestion des contacts =========================================================*/ inputPhoneMini.prototype.attach = function(handler){ diff --git a/public_html/js/includes/min/input-phone-fiche.js b/public_html/js/includes/min/input-phone-fiche.js index 3ac621e..3ef8b8a 100644 --- a/public_html/js/includes/min/input-phone-fiche.js +++ b/public_html/js/includes/min/input-phone-fiche.js @@ -1,23 +1,20 @@ -function inputPhoneFiche(a,c){this.container=a;this.nav_container=c;this.top_size=10}inputPhoneFiche.prototype={container:this.container,nav_container:this.nav_container,selected:0,handler:null,defaultData:{sexe:"2",age:".",job:".",famsit:"0",studies:"0",reltype:"0",reltypeSpecial:"",city:"",quartier:"",cp:"",loc:"0",duration:["",""],context:"0",contextSpecial:["","",""],freq:["4","9","14","19","24"],connect:"1 3 5 7 9 11".split(" "),connectSpecial:["",""],timestamp:0,valid:!1}}; -inputPhoneFiche.prototype.fieldsToStorage=function(){console.group("[phone.fiche] fields to storage");var a,c,b,d,k,e=$$('[data-sublink="phone"] article.relation-panel .fiche-relation');a=0;for(c=e.length;a FICHE UPDATE ("+(d.timestamp-input_ts)+")"),lsi.set("p_fiches",d.uid,d);console.groupEnd()}; +function inputPhoneFiche(a,b){this.container=a;this.nav_container=b;this.top_size=10}inputPhoneFiche.prototype={container:this.container,nav_container:this.nav_container,selected:0,handler:null,defaultData:{sexe:"2",age:".",job:".",famsit:"0",studies:"0",reltype:"0",reltypeSpecial:"",city:"",quartier:"",cp:"",loc:"0",duration:["",""],context:"0",contextSpecial:["","",""],freq:["4","9","14","19","24"],connect:"1 3 5 7 9 11".split(" "),connectSpecial:["",""],timestamp:0,valid:!1}}; +inputPhoneFiche.prototype.fieldsToStorage=function(){console.group("[phone.fiche] fields to storage");var a,b,c,d,e,f=$$('[data-sublink="phone"] article.relation-panel .fiche-relation');a=0;for(b=f.length;a FICHE UPDATE ("+(d.timestamp-input_ts)+")",c,d),lsi.set("p_fiches",d.uid,d);console.groupEnd()}; inputPhoneFiche.prototype.add=function(a){if(null==a.uid||isNaN(a.uid)||null==a.contact||isNaN(a.contact))return!1;a.city=null!=a.city?a.city:this.defaultData.city;a.quartier=null!=a.quartier?a.quartier:this.defaultData.quartier;a.cp=null!=a.cp?a.cp:this.defaultData.cp;a.duration[0]=null!=a.duration[0]?a.duration[0]:this.defaultData.duration[0];a.duration[1]=null!=a.duration[1]?a.duration[1]:this.defaultData.duration[1];a.reltypeSpecial=null!=a.reltypeSpecial?a.reltypeSpecial:this.defaultData.reltypeSpecial; a.contextSpecial[0]=null!=a.contextSpecial[0]?a.contextSpecial[0]:this.defaultData.contextSpecial[0];a.contextSpecial[1]=null!=a.contextSpecial[1]?a.contextSpecial[1]:this.defaultData.contextSpecial[1];a.contextSpecial[2]=null!=a.contextSpecial[2]?a.contextSpecial[2]:this.defaultData.contextSpecial[2];a.connectSpecial[0]=null!=a.connectSpecial[0]?a.connectSpecial[0]:this.defaultData.connectSpecial[0];a.connectSpecial[1]=null!=a.connectSpecial[1]?a.connectSpecial[1]:this.defaultData.connectSpecial[1]; a.job=null!=a.job?a.job:this.defaultData.job;a.studies=null!=a.studies?a.studies:this.defaultData.studies;a.age=null!=a.age?a.age:this.defaultData.age;a.sexe=null!=a.sexe?a.sexe:this.defaultData.sexe;a.famsit=null!=a.famsit?a.famsit:this.defaultData.famsit;a.reltype=null!=a.reltype?a.reltype:this.defaultData.reltype;a.loc=null!=a.loc?a.loc:this.defaultData.loc;a.context=null!=a.context?a.context:this.defaultData.context;a.freq=null!=a.freq?a.freq:this.defaultData.freq;a.connect=null!=a.connect?a.connect: -this.defaultData.connect;var c=lsi.get("p_contacts",a.contact);if(!1===c)return!1;var b="";isNaN(c.existing)||(b=lsi.get("p_friends",c.existing),c.username=b.name,a.age=b.age,a.sexe=b.sexe,a.loc=b.dist,isNaN(b.reltype)?(a.reltype=10,a.reltypeSpecial=b.reltype):(a.reltype=b.reltype,a.reltypeSpecial=""),null!=b.studies2?(a.studies=b.studies2,a.job=b.job,a.famsit=b.famsit,a.city=b.city,a.cp=b.cp,a.quartier=b.quartier,a.duration[0]=b.duration[0],a.duration[1]=b.duration[1],a.context=b.context,a.contextSpecial= -b.contextExtra,a.connect=b.connect,a.connectSpecial=b.connectExtra,a.freq=b.freq,b="Contact import\u00e9: non modifiable!"):b="Contact import\u00e9 (incomplet): modifiable partiellement!");this.container.innerHTML+=pFicheBuilder.build({importedfiche:b,name:c.username,countcall:c.countcall,countsms:c.countsms,uid:a.uid,contact:a.contact,city:a.city,quartier:a.quartier,cp:a.cp,duration0:a.duration[0],duration1:a.duration[1],reltypespecial:a.reltypeSpecial,contextspecial0:a.contextSpecial[0],contextspecial1:a.contextSpecial[1], -contextspecial2:a.contextSpecial[2],connectspecial0:a.connectSpecial[0],connectspecial1:a.connectSpecial[1]});c=$('[data-sublink="phone"] article.fiche-relation input[data-name="uid"][value="'+a.uid+'"] ~ h5>span>select[data-name="job"]>option[value="'+a.job+'"]');null!=c&&c.setAttribute("selected","selected");c=$('[data-sublink="phone"] article.fiche-relation input[data-name="uid"][value="'+a.uid+'"] ~ h5>span>select[data-name="studies"]>option[value="'+a.studies+'"]');null!=c&&c.setAttribute("selected", -"selected");c=$('[data-sublink="phone"] article.fiche-relation input[data-name="uid"][value="'+a.uid+'"] ~ h5>span>select[data-name="age"]>option[value="'+a.age+'"]');null!=c&&c.setAttribute("selected","selected");b=$$('[data-sublink="phone"] article.fiche-relation input[data-name="uid"][value="'+a.uid+'"] ~ h5>input[type="radio"][data-name="sexe"]');for(c=0;cinput[type="radio"][data-name="famsit"]');for(c=0;cinput[type="radio"][data-name="reltype"]');for(c=0;cinput[type="radio"][data-name="loc"]');for(c=0;cinput[type="radio"][data-name="context"]');for(c=0;cinput[type="radio"][data-name="freq"]');for(c=0;cinput[type="radio"][data-name="connect"]');for(c=0;c=d)break}var e,f,h,d={};k={};var a=lsi["export"]("p_fiches"), -c=lsi["export"]("p_mini-fiches"),l;for(l in a)if(e=lsi.get("p_contacts",a[l].contact),!(0 span.active'),b=0;bAPPELS");20>d&&b'+(d%20+1)+"  ":(20==d&&(this.nav_container.innerHTML+='
   SMS   '),this.nav_container.innerHTML+=''+(d%20+1)+"")}for(var k in a)c=$('[data-sublink="phone"] #p_nav-fiche [data-n="'+a[k].uid+'"]'),null!=c&&(!0===a[k].valid?c.addClass("done"):c.remClass("done"));this.nav($('[data-sublink="phone"] #p_nav-fiche [data-n="'+this.selected+'"]'))}; -inputPhoneFiche.prototype.check=function(a){if(2>a.city.length||isNaN(parseInt(a.duration[0]))&&0a.reltypeSpecial.length|| +this.defaultData.connect;var b=lsi.get("p_contacts",a.contact);if(!1===b)return!1;var c="";isNaN(b.existing)||(c=lsi.get("p_friends",b.existing),b.username=c.name,a.age=c.age,a.sexe=c.sexe,a.loc=c.dist,isNaN(c.reltype)?(a.reltype=10,a.reltypeSpecial=c.reltype):(a.reltype=c.reltype,a.reltypeSpecial=""),null!=c.studies2?(a.studies=c.studies2,a.job=c.job,a.famsit=c.famsit,a.city=c.city,a.cp=c.cp,a.quartier=c.quartier,a.duration[0]=c.duration[0],a.duration[1]=c.duration[1],a.context=c.context,a.contextSpecial= +c.contextExtra,a.connect=c.connect,a.connectSpecial=c.connectExtra,a.freq=c.freq,c="Contact import\u00e9: non modifiable!"):c="Contact import\u00e9 (incomplet): modifiable partiellement!");this.container.innerHTML+=pFicheBuilder.build({importedfiche:c,name:b.username,countcall:b.countcall,countsms:b.countsms,uid:a.uid,contact:a.contact,city:a.city,quartier:a.quartier,cp:a.cp,duration0:a.duration[0],duration1:a.duration[1],reltypespecial:a.reltypeSpecial,contextspecial0:a.contextSpecial[0],contextspecial1:a.contextSpecial[1], +contextspecial2:a.contextSpecial[2],connectspecial0:a.connectSpecial[0],connectspecial1:a.connectSpecial[1]});b=$('[data-sublink="phone"] article.fiche-relation input[data-name="uid"][value="'+a.uid+'"] ~ h5>span>select[data-name="job"]>option[value="'+a.job+'"]');null!=b&&b.setAttribute("selected","selected");b=$('[data-sublink="phone"] article.fiche-relation input[data-name="uid"][value="'+a.uid+'"] ~ h5>span>select[data-name="studies"]>option[value="'+a.studies+'"]');null!=b&&b.setAttribute("selected", +"selected");b=$('[data-sublink="phone"] article.fiche-relation input[data-name="uid"][value="'+a.uid+'"] ~ h5>span>select[data-name="age"]>option[value="'+a.age+'"]');null!=b&&b.setAttribute("selected","selected");c=$$('[data-sublink="phone"] article.fiche-relation input[data-name="uid"][value="'+a.uid+'"] ~ h5>input[type="radio"][data-name="sexe"]');for(b=0;binput[type="radio"][data-name="famsit"]');for(b=0;binput[type="radio"][data-name="reltype"]');for(b=0;binput[type="radio"][data-name="loc"]');for(b=0;binput[type="radio"][data-name="context"]');for(b=0;binput[type="radio"][data-name="freq"]');for(b=0;binput[type="radio"][data-name="connect"]');for(b=0;b=c)break}console.groupEnd()}; +inputPhoneFiche.prototype.nav=function(a){if(!(a instanceof Element&&a.getData("n"))||isNaN(a.getData("n"))||"p_nav-fiche"!=a.parentNode.id)return!1;for(var b=$$('[data-sublink="phone"] #p_nav-fiche > span.active'),c=0;cAPPELS");20>d&&c'+(d%20+1)+"  ":(20==d&&(this.nav_container.innerHTML+='
   SMS   '),this.nav_container.innerHTML+=''+(d%20+1)+"")}for(var e in a)b=$('[data-sublink="phone"] #p_nav-fiche [data-n="'+a[e].uid+'"]'),null!=b&&(!0===a[e].valid?b.addClass("done"):b.remClass("done"));this.nav($('[data-sublink="phone"] #p_nav-fiche [data-n="'+this.selected+'"]'))}; +inputPhoneFiche.prototype.check=function(a){if(2>a.city.length||isNaN(parseInt(a.duration[0]))&&0a.reltypeSpecial.length|| "11"==a.context&&2>a.contextSpecial[0].length||"12"==a.context&&2>a.contextSpecial[1].length||"13"==a.context&&2>a.contextSpecial[2].length?!1:!0};inputPhoneFiche.prototype.attach=function(a){console.group("[phone.fiche] attaching events");lsi.createDataset("p_fiches");this.storageToFields();this.handler=a;this.nav_container.addEventListener("click",function(a){this.nav(a.target);this.handler(a.target)}.bind(this),!1);console.groupEnd()}; diff --git a/public_html/js/includes/min/input-phone-mini.js b/public_html/js/includes/min/input-phone-mini.js index 80db3b5..1f43722 100644 --- a/public_html/js/includes/min/input-phone-mini.js +++ b/public_html/js/includes/min/input-phone-mini.js @@ -1,14 +1,14 @@ -function inputPhoneMini(a,c){this.container=a;this.nav_container=c}inputPhoneMini.prototype={container:this.container,nav_container:this.nav_container,selected:null,handler:null,defaultData:{contact:null,sexe:"2",age:".",studies:"0",loc:".",reltype:"9",reltypeSpecial:"",unknown:!1,timestamp:0,valid:!1}}; -inputPhoneMini.prototype.fieldsToStorage=function(){console.group("[phone.mini] fields to storage");for(var a=$$('[data-sublink="phone"] article.mini-relation-panel .mini-fiche-relation'),c=0;c MINI UPDATE ("+(b.timestamp-input_ts)+")")),void 0!=d.timestamp&&isNaN(d.timestamp)||(b.timestamp=Date.now())):void 0!=d.timestamp&&isNaN(d.timestamp)||(b.timestamp=0);console.warn("saving mini#"+ -b.uid+" with timestamp of "+b.timestam+" and hash of "+d.hash+" and now "+b.hash);lsi.set("p_mini-fiches",b.uid,b)}}console.groupEnd()}; -inputPhoneMini.prototype.add=function(a){if(null==a||null==a.uid)return!1;a.age=null!=a.age?a.age:this.defaultData.age;a.sexe=null!=a.sexe?a.sexe:this.defaultData.sexe;a.studies=null!=a.studies?a.studies:this.defaultData.studies;a.reltype=null!=a.reltype?a.reltype:this.defaultData.reltype;a.reltypeSpecial=null!=a.reltypeSpecial?a.reltypeSpecial:this.defaultData.reltypeSpecial;a.loc=null!=a.loc?a.loc:this.defaultData.loc;a.unknown=null!=a.unknown?a.unknown:this.defaultData.unknown;var c=lsi.get("p_contacts", -a.uid);if(!1===c)return!1;if(!isNaN(c.existing)){var b=lsi.get("p_friends",c.existing);c.username=b.name;a.contact=c.uid;a.age=b.age;a.sexe=b.sexe;a.loc=b.dist;isNaN(b.reltype)?(a.reltype=10,a.reltypeSpecial=b.reltype):(a.reltype=b.reltype,a.reltypeSpecial="");null!=b.studies1&&(a.studies=b.studies1)}this.container.innerHTML+=pMiniFicheBuilder.build({name:c.username,countcall:c.countcall,countsms:c.countsms,uid:a.uid,reltypespecial:a.reltypeSpecial});c=$('[data-sublink="phone"] article.mini-fiche-relation input[data-name="uid"][value="'+ -a.uid+'"] ~ h5>span>select[data-name="studies"]>option[value="'+a.studies+'"]');null!=c&&c.setAttribute("selected","selected");c=$('[data-sublink="phone"] article.mini-fiche-relation input[data-name="uid"][value="'+a.uid+'"] ~ h5>span>select[data-name="age"]>option[value="'+a.age+'"]');null!=c&&c.setAttribute("selected","selected");b=$$('[data-sublink="phone"] article.mini-fiche-relation input[data-name="uid"][value="'+a.uid+'"] ~ h5>input[type="radio"][data-name="sexe"]');for(c=0;cinput[type="radio"][data-name="reltype"]');for(c=0;cinput[type="radio"][data-name="loc"]');for(c=0;cinput[type="checkbox"][data-name="unknown"]');null!=c&&a.unknown&&c.setAttribute("checked","checked")}; -inputPhoneMini.prototype.storageToFields=function(){console.group("[phone.mini] storage to fields");var a=lsi.get("p_mini-fiches",this.selected);if(null===a){if(null===this.selected)return a=lsi.keys("p_mini-fiches"),0 span.active'),b=0;b'+ ++c+"");for(b in a)isNaN(b)||(c=$('[data-sublink="phone"] #p_nav-mini [data-n="'+a[b].uid+'"]'),null!=c&&(!0===a[b].valid?c.addClass("done"):c.remClass("done")));this.nav($('[data-sublink="phone"] #p_nav-mini [data-n="'+this.selected+'"]'))}; +function inputPhoneMini(a,b){this.container=a;this.nav_container=b}inputPhoneMini.prototype={container:this.container,nav_container:this.nav_container,selected:null,handler:null,defaultData:{contact:null,sexe:"2",age:".",studies:"0",loc:".",reltype:"9",reltypeSpecial:"",unknown:!1,timestamp:0,valid:!1}}; +inputPhoneMini.prototype.fieldsToStorage=function(){console.group("[phone.mini] fields to storage");var a,b,c,d,e,f=$$('[data-sublink="phone"] article.mini-relation-panel .mini-fiche-relation');a=0;for(b=f.length;a MINI UPDATE ("+(d.timestamp-input_ts)+")"),lsi.set("p_mini-fiches",d.uid,d);console.groupEnd()}; +inputPhoneMini.prototype.add=function(a){if(null==a||null==a.uid)return!1;a.age=null!=a.age?a.age:this.defaultData.age;a.sexe=null!=a.sexe?a.sexe:this.defaultData.sexe;a.studies=null!=a.studies?a.studies:this.defaultData.studies;a.reltype=null!=a.reltype?a.reltype:this.defaultData.reltype;a.reltypeSpecial=null!=a.reltypeSpecial?a.reltypeSpecial:this.defaultData.reltypeSpecial;a.loc=null!=a.loc?a.loc:this.defaultData.loc;a.unknown=null!=a.unknown?a.unknown:this.defaultData.unknown;var b=lsi.get("p_contacts", +a.uid);if(!1===b)return!1;if(!isNaN(b.existing)){var c=lsi.get("p_friends",b.existing);b.username=c.name;a.contact=b.uid;a.age=c.age;a.sexe=c.sexe;a.loc=c.dist;isNaN(c.reltype)?(a.reltype=10,a.reltypeSpecial=c.reltype):(a.reltype=c.reltype,a.reltypeSpecial="");null!=c.studies1&&(a.studies=c.studies1)}this.container.innerHTML+=pMiniFicheBuilder.build({name:b.username,countcall:b.countcall,countsms:b.countsms,uid:a.uid,reltypespecial:a.reltypeSpecial});b=$('[data-sublink="phone"] article.mini-fiche-relation input[data-name="uid"][value="'+ +a.uid+'"] ~ h5>span>select[data-name="studies"]>option[value="'+a.studies+'"]');null!=b&&b.setAttribute("selected","selected");b=$('[data-sublink="phone"] article.mini-fiche-relation input[data-name="uid"][value="'+a.uid+'"] ~ h5>span>select[data-name="age"]>option[value="'+a.age+'"]');null!=b&&b.setAttribute("selected","selected");c=$$('[data-sublink="phone"] article.mini-fiche-relation input[data-name="uid"][value="'+a.uid+'"] ~ h5>input[type="radio"][data-name="sexe"]');for(b=0;binput[type="radio"][data-name="reltype"]');for(b=0;binput[type="radio"][data-name="loc"]');for(b=0;binput[type="checkbox"][data-name="unknown"]');null!=b&&a.unknown&&b.setAttribute("checked","checked")}; +inputPhoneMini.prototype.storageToFields=function(){console.group("[phone.mini] storage to fields");var a=lsi["export"]("p_mini-fiches"),b=lsi.keys("p_mini-fiches");if(null===(void 0!=a[this.selected]?a[this.selected]:null)){if(null===this.selected){if(0==b.length)return!1;this.selected=b[0];return this.storageToFields()}this.updateNavBar();return!1}this.container.innerHTML="";for(var c in a)b=cloneObject(a[c]),delete b.hash,delete b.timestamp,delete b.valid,a[c].hash=crc32(JSON.stringify(b)),lsi.set("p_fiches", +a[c].uid,a[c]),a[c].uid==this.selected&&this.add(a[c]);this.updateNavBar();console.groupEnd()}; +inputPhoneMini.prototype.sync=function(){console.group("[phone.mini] synchronisation");var a=lsi["export"]("p_contacts"),b;ficheIndexes=lsi.keys("p_fiches");for(b in ficheIndexes)delete a[ficheIndexes[b]];for(var c in a){var d=0==a[c].username.length?c.toString()+"-":c;b=lsi.get("p_mini-fiches",d);null==b&&(b=this.defaultData,b.contact=a[c].uid,b.valid=!1);b.uid=parseInt(c);lsi.set("p_mini-fiches",d,b)}b=lsi["export"]("p_mini-fiches");if(null==b[this.selected])for(c in b)if(!isNaN(c)){this.selected= +parseInt(c);break}console.groupEnd()};inputPhoneMini.prototype.nav=function(a){if(!(a instanceof Element&&a.getData("n"))||isNaN(a.getData("n"))||"p_nav-mini"!=a.parentNode.id)return!1;for(var b=$$('[data-sublink="phone"] #p_nav-mini > span.active'),c=0;c'+ ++b+"");for(c in a)isNaN(c)||(b=$('[data-sublink="phone"] #p_nav-mini [data-n="'+a[c].uid+'"]'),null!=b&&(!0===a[c].valid?b.addClass("done"):b.remClass("done")));this.nav($('[data-sublink="phone"] #p_nav-mini [data-n="'+this.selected+'"]'))}; inputPhoneMini.prototype.check=function(a){return a.unknown?!0:""==a.sexe||"."==a.studies||"."==a.age||""==a.loc||""==a.reltype||"10"==a.reltype&&2>a.reltypeSpecial.length?!1:!0};inputPhoneMini.prototype.attach=function(a){console.group("[phone.mini] attaching events");lsi.createDataset("p_mini-fiches");this.storageToFields();this.handler=a;this.nav_container.addEventListener("click",function(a){this.nav(a.target);this.handler(a.target)}.bind(this),!1);console.groupEnd()};