/* [0] Constructeur -> définit le conteneur et le bouton d'ajout =========================================================*/ function inputFacebookMatrice(container){ this.container = container; } /* [1] Attributs =========================================================*/ inputFacebookMatrice.prototype = { container: this.container // Conteneur de la matrice }; /* [2] Gestion de l'enregistrement de la matrice =========================================================*/ inputFacebookMatrice.prototype.fieldsToStorage = function(){ console.group('[facebook.matrice] fields to storage'); // {1} On initialise notre deflater pour récupérer les valeurs // var deflater = new FormDeflater(this.container, ['input'], ['data-name']); // {2} On extrait les données // var deflated = deflater.deflate(); // On crée le hash var deflatedHash = crc32(JSON.stringify(deflated)); // console.log(deflated); /* (3) On crée l'objet et on le remplit avec les relations */ var obj = {}; for( var i in deflated ) // {1} Si c'est un tableau de sujets // if( deflated[i] instanceof Array ){ // Pour chacune des différentes relations, on ajoute si TRUE for( var a in deflated[i] ){ if( obj[i] == null ) obj[i] = []; obj[i].push( parseInt(deflated[i][a]) ); } // {2} Si il n'y a qu'un sujet // }else if( deflated[i] !== null ){ if( obj[i] == null ) obj[i] = []; obj[i].push( parseInt(deflated[i]) ); } lsi.set( 'f_matrice', 0, obj ); // Objet de la forme // // idA: [idV, idW], # A connait V et W (et réciproquement) // idB: [idX, idY], # B connait X et Y (et réciproquement) // ... // console.groupEnd(); }; /* [4] Gestion de l'affichage depuis le 'localStorage' =========================================================*/ inputFacebookMatrice.prototype.storageToFields = function(){ console.group('[facebook.matrice] storage to fields'); /* (1) On récupère la liste des contacts à mettre dans la matrice */ // On récupère les fiches var ficheData = lsi.export('f_fiches'); // On récupère les données de la matrice var matriceData = lsi.get('f_matrice', 0); // On récupère les contacts pour afficher les noms/prénoms var contactData = lsi.export('f_contacts'); // Contiendra les UID des contacts à mettre dans la matrice var contacts = []; // Pour chaque fiche, on ajoute l'uid du contact s'il n'est pas déja ajouté for( var f in ficheData ) if( contacts.indexOf( ficheData[f].contact ) == -1 ) contacts.push( ficheData[f].contact ); /* (2) On construit le HTML de la matrice */ // Contiendra le HTML var matrice_html = ["
'); matrice_html.push(conA.username); matrice_html.push(' | '); }else // Sinon, matrice_html.push(''); // {2} Pour chaque case // for( var B = 0 ; B < contacts.length ; B++ ){ if( B < contacts.length-1 ){ var conB = contactData[B]; // {3} Première colonne -> Intitulé des ordonnées // if( A == 0 ){ matrice_html.push(' | '); matrice_html.push(''); matrice_html.push(conB.username); matrice_html.push(''); // {4} Valeurs des relations (boutons) // }else if( B < A ){ matrice_html.push(" | "); matrice_html.push(" -1 ) matrice_html.push(" checked"); matrice_html.push(" >"); matrice_html.push(""); // {5} Cases vides (moitié supérieure droite) // }else matrice_html.push(" | "); matrice_html.push(' | '); }} matrice_html.push('