2016-05-18 12:46:13 +00:00
|
|
|
/* [0] Constructeur -> définit le conteneur et le bouton d'ajout
|
|
|
|
=========================================================*/
|
2016-12-13 18:37:44 +00:00
|
|
|
function inputFacebookSubject(iSubjectId, iCoords, store_button){
|
2016-05-26 14:47:15 +00:00
|
|
|
this.subject_id = iSubjectId;
|
2016-12-13 18:37:44 +00:00
|
|
|
this.coords = iCoords;
|
2016-05-18 12:46:13 +00:00
|
|
|
this.store_button = store_button;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* [1] Attributs
|
|
|
|
=========================================================*/
|
|
|
|
inputFacebookSubject.prototype = {
|
|
|
|
store_button: this.store_button, // Bouton d'ajout d'un formulaire
|
2016-05-30 16:44:37 +00:00
|
|
|
subject_id: this.subject_id,
|
2016-12-13 18:37:44 +00:00
|
|
|
coords: this.coords,
|
2016-05-30 16:44:37 +00:00
|
|
|
handler: null
|
2016-05-18 12:46:13 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/* [2] Vérification d'un formulaire
|
|
|
|
=========================================================*/
|
|
|
|
inputFacebookSubject.prototype.check = function(){
|
|
|
|
// On renvoie la validité du formulaire
|
2016-05-26 14:47:15 +00:00
|
|
|
return this.subject_id.value.length > 0 && !isNaN(this.subject_id.value);
|
2016-05-18 12:46:13 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* [3] Gestion de l'enregistrement des formulaires de contact
|
|
|
|
=========================================================*/
|
|
|
|
inputFacebookSubject.prototype.fieldsToStorage = function(){
|
2016-10-12 14:20:46 +00:00
|
|
|
console.group('[facebook.subject] fields to storage');
|
2016-05-18 12:46:13 +00:00
|
|
|
|
|
|
|
// {1} Si le formulaire n'est pas valide, on ne l'enregistre pas //
|
|
|
|
if( !this.check() ) return false;
|
|
|
|
|
2016-10-12 15:37:21 +00:00
|
|
|
// {2} Si on a déja saisie 1+ contact, on ne l'enregistre pas //
|
|
|
|
if( lsi.keys('f_contacts').length > 0 ){
|
|
|
|
Notification.warning('Attention', 'Vous devez effacer le formulaire pour changer de sujet');
|
|
|
|
return false;
|
|
|
|
}
|
2016-05-18 12:46:13 +00:00
|
|
|
|
2016-10-12 15:37:21 +00:00
|
|
|
// {3} On récupère et met en forme les valeurs du deflater //
|
2016-12-13 18:37:44 +00:00
|
|
|
var obj = { subject_id: this.subject_id.value, coords: this.coords.value };
|
2016-10-12 15:37:21 +00:00
|
|
|
|
|
|
|
// {4} On enregistre les données dans le 'localStorage' //
|
2016-05-18 13:28:02 +00:00
|
|
|
lsi.set('f_subject', 0, obj);
|
2016-05-18 12:46:13 +00:00
|
|
|
|
2016-10-12 14:20:46 +00:00
|
|
|
console.groupEnd();
|
2016-05-18 12:46:13 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* [4] Gestion de l'affichage depuis le 'localStorage'
|
|
|
|
=========================================================*/
|
|
|
|
inputFacebookSubject.prototype.storageToFields = function(){
|
2016-10-12 14:20:46 +00:00
|
|
|
console.group('[facebook.subject] storage to fields');
|
2016-05-18 12:46:13 +00:00
|
|
|
|
|
|
|
// {1} On récupère les informations du sujet //
|
2016-05-18 13:28:02 +00:00
|
|
|
var subjectData = lsi.get('f_subject', 0);
|
2016-05-18 12:46:13 +00:00
|
|
|
|
2016-12-13 18:37:44 +00:00
|
|
|
subjectData = subjectData || { subject_id: '', coords: '' };
|
2016-05-18 12:46:13 +00:00
|
|
|
|
|
|
|
// {2} On restore les valeurs //
|
2016-12-13 18:37:44 +00:00
|
|
|
this.subject_id.value = subjectData.subject_id;
|
|
|
|
this.coords.value = subjectData.coords;
|
2016-10-12 14:20:46 +00:00
|
|
|
|
|
|
|
console.groupEnd();
|
2016-05-18 12:46:13 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* [5] Point d'amorçage de la gestion des contacts
|
|
|
|
=========================================================*/
|
2016-05-30 16:44:37 +00:00
|
|
|
inputFacebookSubject.prototype.attach = function(handler){
|
2016-10-12 14:20:46 +00:00
|
|
|
console.group('[facebook.subject] attaching events');
|
2016-05-18 12:46:13 +00:00
|
|
|
|
|
|
|
/* (1) On initialise le jeu de données */
|
2016-05-18 13:28:02 +00:00
|
|
|
lsi.createDataset('f_subject');
|
2016-05-30 16:44:37 +00:00
|
|
|
lsi.createDataset('f_friends');
|
2016-05-18 12:46:13 +00:00
|
|
|
|
|
|
|
// Pointeur pour les scopes des addEventListener()
|
2016-05-30 16:44:37 +00:00
|
|
|
this.handler = handler;
|
2016-05-18 12:46:13 +00:00
|
|
|
var ptr = this;
|
|
|
|
// Handler de mise à jour quand les champs sont bons
|
2016-05-30 16:44:37 +00:00
|
|
|
function fts(e){ ptr.fieldsToStorage(); ptr.handler(true); ptr.storageToFields(); }
|
2016-05-18 12:46:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* (2) On attache l'évènement sur le bouton d'enregistrement */
|
|
|
|
this.store_button.addEventListener('click', fts, false);
|
|
|
|
|
|
|
|
/* (3) On attache un évènement de 'blur' sur chaque '<input type="text">' */
|
2016-05-30 16:44:37 +00:00
|
|
|
this.subject_id.addEventListener('blur', fts, false);
|
2016-05-18 12:46:13 +00:00
|
|
|
|
2016-12-13 18:37:44 +00:00
|
|
|
/* (4) On attache un évènement pour le champ coord */
|
|
|
|
this.coords.addEventListener('blur', fts, false);
|
|
|
|
|
2016-05-18 12:46:13 +00:00
|
|
|
/* (4) On charge le sujet depuis la mémoire ('localStorage') */
|
|
|
|
this.storageToFields();
|
2016-10-12 14:20:46 +00:00
|
|
|
|
|
|
|
console.groupEnd();
|
2016-05-18 12:46:13 +00:00
|
|
|
};
|