[AngularJs] placer un watcher (surveillance) sur un objet complet JSON

angularjs-300x300
Introduction

Si on veut surveiller un objet JSON en temps réel, et pas seulement un ensemble clef valeur, la syntaxe est différente .
RAPPEL : Un objet Json peut contenir tout un formulaire et des tas de données diverses, en TEMPS REEL, avec angularJs et le 2 ways binding. Un watcher peut servir à sauver un form en local Storage, au cas ou la personne pars de l’app pendant quelques temps .

Le code :

Sur un objet de ce type :

 $scope.form = {
        name: 'my name',
        surname: 'surname'
    }

Le watcher -> Ajouter true:
Call $watch with true as the third argument:

$scope.$watch('form', function(newVal, oldVal){
    console.log('changed');
}, true);

Lien :
https://stackoverflow.com/questions/19455501/watch-an-object

Publicités

[AngularJs] Filtre qui calcule l’age d’une personne en fonction de la date de naissance .

angularjs-300x300
Introduction

un filtre qui calcule l’age d’une personne en fonction de sa DDN

Le code :

app.filter('ageFilter', function() {
     function calculateAge(birthday) { // birthday is a date
         var ageDifMs = Date.now() - birthday.getTime();
         var ageDate = new Date(ageDifMs); // miliseconds from epoch
         return Math.abs(ageDate.getUTCFullYear() - 1970);
     }

     return function(birthdate) { 
           return calculateAge(birthdate);
     }; 
});

Utiliser dans une vue:

{{ footballeur.date_naissance | ageFilter }}

[Json] Encoder toutes les photos d’une application en base64

angularjs-300x300
Introduction

Ouiiin , J’ai Pas envie de stocker les photos des gens sur mon server au format JPEG ou BMP ou TIFF etc … ?

Il faut alors Encoder en Base 64 toutes les photos, puis les placer en base de donnée.

Code Compatible big data ou relationnel avec un bouton qui permet lupload, et le convertisseur base 64 …
Pour encoder une image en ligne : https://www.base64-image.de/

Le Code :
Dans la vue Html, un img src pour afficher et un boutton pour uploader :

// Limage 
<img src="{{footballeur.photo ||'defaut.png'}}" />

// Le bouton 
<div id="upload_button">
	<label>
	<input name="inputFileToLoad" id="inputFileToLoad" ng-model="logo"  type="file"  onchange=""  /> </input>
	<span class="btn btn-primary">Modifier la photo</span>
	</label>
</div>

Le code Front
Le code AngularJs (version $scope)qui permet de récupérer une photo, et le convertit en base 64 , ensuite, il ne reste plus qu’à le mettre en bdd big data ou relationnelle.

// GESTION UPLOAD PHOTO 
 $scope.encodeImageFileAsURL = function() {
		
		var filesSelected = document.getElementById("inputFileToLoad").files;
		if (filesSelected.length > 0) {
		  var fileToLoad = filesSelected[0];

		  var fileReader = new FileReader();

		  fileReader.onload = function(fileLoadedEvent) {
			
                        var srcData = fileLoadedEvent.target.result; // <--- data: base64
			
			$scope.footballeur.photo = srcData ; // Affiche la photo en temps réel dans la vue
			$scope.$apply();
			

		  }
		  fileReader.readAsDataURL(fileToLoad);
		}
	  }
	  $(document).on('change', 'input[type="file"]' , function(){
		$scope.encodeImageFileAsURL();
	
		// R?cup?ration des donn?es de la photo apr?s clic sur UPLOAD
		var file = this.files[0];
		var name = file.name;
		var size = file.size;
		var type = file.type;
	
	}); 

Explication : $(document).on fait office de watcher quand on uploade une photo avec le button . $scope.footballeur.photo contient ensuite la photo coenvertie au format base 64 du footballer Lionel Messi, par exemple, ça ressemble à ça :

 

[Php + AngularJs] En finir avec les messages TRY CATCH une bonne fois pour toute .

angularjs-300x300

Introduction :

Quand une requête SQL est en erreur dans le back end PHP PDO, on peut vouloir voir le message d’erreur SQL s’afficher en direct dans l’application  FRONT END angularJs.

Ce problème est insupportable si l’on gère différement les retours des requêtes $http à chaque fois, il faut donc  etre  géré toujours de la meme manière .
En fait , il s’agit d’un design pattern.

Comment faire :

Etape 1 :Activer l’affichage des erreurs de la connexion PDO : exemple :


$this->bdd = new PDO('mysql:host=' . self::DB_HOST . ';port='. self::PORT . ' ;dbname=' . self::DB_NAME , self::LOGIN , self::PWD);

$this->bdd->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

Note : c’est la 2 ème ligne qui importe .

Etape 2 : Créer une fonction avec un try catch dans une classe PHP, exemple :


  protected function Update($table, $tab_value, $id) {

        try {
			$sql = 'UPDATE ' . $table . ' SET ';

            //  LES NOMS DE CHAMPS ET LEUR VALEUR
            if($tab_value) {
                foreach($tab_value as $i=>$v){
                    $sql .= $i.'= :'.$i.', ';
                }
            } else {
                $tab_value = array();
            }

            //  ENLEVER LA DERNIERE VIRGULE
            $sql = substr($sql, 0, -2);
            $sql .= ' WHERE id_'.$table.' = '.$id;

            $req = $this->bdd->prepare($sql);

            $req->execute($tab_value);

        } catch(PDOException  $e) {
			die('Erreur : '.$e->getMessage());
		}
		return true;
	}

Note : ici , on remarque qu’elle retourne TRUE, seulement à la fin, mais que le CATCH annulera le TRUE si la requête SQL est en erreur, et que le message d’erreur PDO parviendra bien au FRONT END .

Etape 3 :

Appeler la fonction dans le WEB SERVICE en PHP comme ceci (Exemple):

echo json_encode($user ->Update($table, $tab_value, $id));

Etape 4 : Dans le front end , Gérer l’erreur dans AngularJS :

$http.post(webServicesUrl+'?action=UpdateUser',this.utilisateur)
    .then(function (response, status, headers, config) { // return true or the PDO error
	
	if (response.data == "true") {
			 Notification.error({message: 'ok cest bien TRUE', delay: 5000});
			
	} else { 
		 
		 Notification.error({message: response.data, delay: 5000});
		

	}


	 
}.bind(this));

Note : On remarque que TRUE est un string, et que toute autre réponse que TRUE provenant du back end provoque l’affichage de l’erreur dans le FRONT END .

Conclusion :

Il faut désormais toujours utiliser ce pattern pour les requêtes. AngularJs attends soit un TRUE, soit autre chose, et rien d’autres (pas des 1 et des 0 , par exemple (booléens). En fait, il faut choisir, soit en prends les booléens, mais alors on ne récupère pas le message d’erreur PDO ; soit on fait comme plus haut.

Apparté :
En cas de problème :
En fait, le code n’est pas exactement celui ça décrit dans ce cas, car il y a

  • Le web Service
  • La classe Users
  • La classe Query qui comprends des méthodes génériques private pour updater automatiquement n’importe quelle table sql .

De ce fait, le code exact est :
Dans le web service :
echo json_encode($user ->UpdateUser($data));
( ou $data est un objet)
Dans la classe Users :
return $this->update(self::TABLE,$tab_value,$id);
ou les paramêtres sont l’objet $data scindé en plusieurs variables, dont un tableau, la classe query le nécessite.
Dans la classe query, c’est identique à expliqué au début.

[BOOTSTRAP] Recalculer la hauteur de panel-body en fonction de la taille de l’écran, et prendre en compte le fixed nav header.

css3_logo_and_wordmark.svg

Introduction

Pour que le panel-body du panel bootstrap soit toujours de la taille de l’écran .

Un problème insupportable qui doit être réglé une bonne fois pour toute à l’avance pour toute nouvelle app.

Photo :

exemploe.png

Comment faire :

Calculer à la volée et soustraire la hauteur du nav header + la hauteur du panel-footer + la hauteur du panel-header :
Ajouter ceci à style.css :

.panel-body {
	height: calc(100vh - 220px);
}

 

 

[AngularJs] Colorer les champs en erreur

angularjs-300x300

Introduction


Solution rapide :

Lorsque l’on a un formulaire angularjs avec du css bootstrap, on peut colorer les champs en erreur, en laissant html5 opérer.

Comment faire


Une solution vraiment rapide en CSS avec un formulaire initialisé ainsi :

<form name="$root.myForm" id="form_id"  >
	<div class="input-group">
		<span class="input-group-addon stdgp"></i> Prénom</span>
		<input  ng-model="footballeur[0].prenom" type="text " class="form-control"  placeholder="Exemple : Roland"  required></input>
	</div>
</form>

Et un bouton submit ressemblant à ça :

<button  type="submit" form="form_id" ng-disabled="$root.myForm.$invalid  && !$root.myForm.$invalid.date"  ng-click="insertFootballer()" class="btn btn-default "  alt="Remplissez tous les champs"> 

On mets un CSS comme ceci dans style.css :


.ng-invalid{
border:1px solid #f00;
background:yellow;
}

 

Résultat : En temps réel, le champs se colore ou pas si il est manquant (required)

color.jpg

#f00

[JSON] Convertir un objet contenant des tableaux en un seul tableau contenant des objets

 

json_logo-555px

Introduction
Un Problème peu commun, sur lequel je ne vois pas comment faire un MAP direct.

Le lien :
https://stackoverflow.com/questions/54000212/convert-one-object-containing-arrays-of-json-objects-to-one-array

I have this kind of JSON object :

{
group1:[{ id: 1, name: "larry" },{ id: 2, name: "philippe" }],
group2:[{ id: 3, name: "curly" }],
group3:[{ id: 4, name: "moe" }]
}

How can i convert it to a single array like this, using JS or ANGULARJS ? :

[
{ id: 1, name: "larry" },
{ id: 2, name: "philippe" },
{ id: 3, name: "curly" },
{ id: 4, name: "moe" }
]

EDIT 1 : Resolved Thanks a lot for your kind help, this is my final code :

        newArray = [];
        var e = myObject;
        for ( var k in e ) {
            for ( var i in e[k] ) {
                newArray.push(e[k][i]);
            }
        }
     
        return newArray;

EDIT 2: https://stackoverflow.com/users/5201343/harryparkdotio m’a donné un code mille fois plus simple arghhh :

newArray = [];
var e = myObject;
newArray = Object.values(e).flat();

return newArray;