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()};