// import des librairies

#include <ESP8266WiFi.h>
#include <ESP8266WebServer.h>
#include "DHT.h"                  // https://github.com/adafruit/DHT-sensor-library

// Dé-commentez la ligne qui correspond à votre capteur 

//#define DHTTYPE DHT11   // DHT 11
//#define DHTTYPE DHT21   // DHT 21 (AM2301)
#define DHTTYPE DHT22   // DHT 22  (AM2302), AM2321

// Changer vos SSID et Password
const char* ssid = "xxxxx";  
const char* password = "yyyyy";  

// on declare un serveur nommé "serveur" accessible sur le port 80
ESP8266WebServer serveur(80);

// on defini le pin sur lequel est branché la sonde
uint8_t DHTPin = 4;  // D2 --> GPIO4
               
// on configure la sonde DHT.
DHT dht(DHTPin, DHTTYPE);                

// on definit 2 variables de type float pour stocker nos datas
float Temperature;
float Humidity;

// le setup
void setup() {
  Serial.begin(115200);                        // On demarre la com serie
  Serial.println("");
  Serial.println("");
  pinMode(DHTPin, INPUT);                      // On défini le GPIO utilisé par la sonde en entrée
  dht.begin();                                 // On initialise la sonde
  Serial.print("Connexion à ");                // On précise sur la com série qu'on va se connecter
  Serial.println(ssid);                        // Au ssid
  WiFi.begin(ssid, password);                  // On se connecte au Wifi
  while (WiFi.status() != WL_CONNECTED) {      // Tant qu'on est pas connecté on écrit un point toutes les secondes 
  delay(1000);
  Serial.print(".");
  }
  Serial.println("");
  Serial.println("");
  Serial.print("WiFi connecté, IP : ");        // On précise dans la com série qu'on est connecté  
  Serial.println(WiFi.localIP());              // On affiche l'ip dans la com série
  Serial.println("");
  serveur.on("/", handle_OnConnect);           // On défini la fonction a lancer sur la page d'accueil du site web
  serveur.onNotFound(handle_NotFound);         // On défini la fonction a lancer sur une page non trouvée
  serveur.begin();                             // On démarre le serveur web
  Serial.println("Serveur HTTP démarré");      // On précise dans la com série que le serveur a démarré
}

// la boucle
void loop() {  
  serveur.handleClient();       // écoute en boucle sur le serveur si on a un client 
}

// la fonction qui envoie la page d'accueil au serveur

void handle_OnConnect() {
  Temperature = dht.readTemperature(); // Lecture de la température en Celcius
  Humidity = dht.readHumidity();       // Lecture du taux d'humidité 
  serveur.send(200, "text/html", SendHTML(Temperature,Humidity)); // on envoie au serveur notre page web " la fonction SendHTML avec nos datas"
}

// la fonction qui envoie la page d'erreur

void handle_NotFound(){
  serveur.send(404, "text/plain", "Not found");
}

// la fonction qui construit notre page web avec nos datas
// nos datas seront mise à jour par ajax sur la page web

String SendHTML(float Temperaturestat,float Humiditystat){
  String ptr = "<!DOCTYPE html>\n";
  ptr +="<head><meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0, user-scalable=no\">\n";
  ptr +="<title>NodeMCU DHT22</title>\n";
  ptr +="<style>html { font-family: Helvetica; display: inline-block; margin: 0px auto; text-align: center;}\n";
  ptr +="body{margin-top: 50px;} h1 {color: #444444;margin: 50px auto 30px;}\n";
  ptr +="p {font-size: 24px;color: #444444;margin-bottom: 10px;}\n";
  ptr +="</style>\n";
  ptr +="<script>\n";
  ptr +="setInterval(loadDoc,200);\n";
  ptr +="function loadDoc() {\n";
  ptr +="var xhttp = new XMLHttpRequest();\n";
  ptr +="xhttp.onreadystatechange = function() {\n";
  ptr +="if (this.readyState == 4 && this.status == 200) {\n";
  ptr +="document.getElementById(\"webpage\").innerHTML =this.responseText}\n";
  ptr +="};\n";
  ptr +="xhttp.open(\"GET\", \"/\", true);\n";
  ptr +="xhttp.send();\n";
  ptr +="}\n";
  ptr +="</script>\n";
  ptr +="</head>\n";
  ptr +="<body>\n";
  ptr +="<div id=\"webpage\">\n";
  ptr +="<h1>NodeMCU DHT22</h1>\n";  
  ptr +="<p>Temperature: ";
  ptr +=Temperaturestat;
  ptr +="°C</p>";
  ptr +="<p>Humidity: ";
  ptr +=Humiditystat;
  ptr +="%</p>";  
  ptr +="</div>\n";
  ptr +="</body>\n";
  ptr +="</html>\n";
  return ptr;
}