117 lines
6.7 KiB
Arduino
117 lines
6.7 KiB
Arduino
|
/**
|
||
|
* IotWebConf01Minimal.ino -- IotWebConf is an ESP8266/ESP32
|
||
|
* non blocking WiFi/AP web configuration library for Arduino.
|
||
|
* https://github.com/prampec/IotWebConf
|
||
|
*
|
||
|
* Copyright (C) 2018 Balazs Kelemen <prampec+arduino@gmail.com>
|
||
|
*
|
||
|
* This software may be modified and distributed under the terms
|
||
|
* of the MIT license. See the LICENSE file for details.
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* Example: Custom HTML
|
||
|
* Description:
|
||
|
* This example demostrates how to override the default look and feel of the
|
||
|
* config portal.
|
||
|
*
|
||
|
* The first customalization is to add a logo to the config page.
|
||
|
*
|
||
|
* The second customalization is a special javascript, that detects all
|
||
|
* password fields, and adds a small button after each of them with a
|
||
|
* lock on it. By pressing the lock the password became visible/hidden.
|
||
|
*/
|
||
|
|
||
|
#include <IotWebConf.h>
|
||
|
|
||
|
// -- Initial name of the Thing. Used e.g. as SSID of the own Access Point.
|
||
|
const char thingName[] = "testThing";
|
||
|
|
||
|
// -- Initial password to connect to the Thing, when it creates an own Access Point.
|
||
|
const char wifiInitialApPassword[] = "smrtTHNG8266";
|
||
|
|
||
|
DNSServer dnsServer;
|
||
|
WebServer server(80);
|
||
|
|
||
|
IotWebConf iotWebConf(thingName, &dnsServer, &server, wifiInitialApPassword);
|
||
|
|
||
|
// -- Javascript block will be added to the header.
|
||
|
const char CUSTOMHTML_SCRIPT_INNER[] PROGMEM = "\n\
|
||
|
document.addEventListener('DOMContentLoaded', function(event) {\n\
|
||
|
let elements = document.querySelectorAll('input[type=\"password\"]');\n\
|
||
|
for (let p of elements) {\n\
|
||
|
let btn = document.createElement('INPUT'); btn.type = 'button'; btn.value = '🔓'; btn.style.width = 'auto'; p.style.width = '83%'; p.parentNode.insertBefore(btn,p.nextSibling);\n\
|
||
|
btn.onclick = function() { if (p.type === 'password') { p.type = 'text'; btn.value = '🔒'; } else { p.type = 'password'; btn.value = '🔓'; } }\n\
|
||
|
};\n\
|
||
|
});\n";
|
||
|
// -- HTML element will be added inside the body element.
|
||
|
const char CUSTOMHTML_BODY_INNER[] PROGMEM = "<div><img src='data:image/png;base64, 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'/></div>\n";
|
||
|
|
||
|
// -- This is an OOP technique to override behaviour of the existing
|
||
|
// IotWebConfHtmlFormatProvider. Here two method are overriden from
|
||
|
// the original class. See IotWebConf.h for all potentially overridable
|
||
|
// methods of IotWebConfHtmlFormatProvider .
|
||
|
class CustomHtmlFormatProvider : public IotWebConfHtmlFormatProvider
|
||
|
{
|
||
|
protected:
|
||
|
String getScriptInner() override
|
||
|
{
|
||
|
return
|
||
|
IotWebConfHtmlFormatProvider::getScriptInner() +
|
||
|
String(FPSTR(CUSTOMHTML_SCRIPT_INNER));
|
||
|
}
|
||
|
String getBodyInner() override
|
||
|
{
|
||
|
return
|
||
|
String(FPSTR(CUSTOMHTML_BODY_INNER)) +
|
||
|
IotWebConfHtmlFormatProvider::getBodyInner();
|
||
|
}
|
||
|
};
|
||
|
// -- An instance must be created from the class defined above.
|
||
|
CustomHtmlFormatProvider customHtmlFormatProvider;
|
||
|
|
||
|
void setup()
|
||
|
{
|
||
|
Serial.begin(115200);
|
||
|
Serial.println();
|
||
|
Serial.println("Starting up...");
|
||
|
|
||
|
// -- Applying the new HTML format to IotWebConf.
|
||
|
iotWebConf.setHtmlFormatProvider(&customHtmlFormatProvider);
|
||
|
iotWebConf.init();
|
||
|
|
||
|
// -- Set up required URL handlers on the web server.
|
||
|
server.on("/", handleRoot);
|
||
|
server.on("/config", []{ iotWebConf.handleConfig(); });
|
||
|
server.onNotFound([](){ iotWebConf.handleNotFound(); });
|
||
|
|
||
|
Serial.println("Ready.");
|
||
|
}
|
||
|
|
||
|
void loop()
|
||
|
{
|
||
|
// -- doLoop should be called as frequently as possible.
|
||
|
iotWebConf.doLoop();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Handle web requests to "/" path.
|
||
|
*/
|
||
|
void handleRoot()
|
||
|
{
|
||
|
// -- Let IotWebConf test and handle captive portal requests.
|
||
|
if (iotWebConf.handleCaptivePortal())
|
||
|
{
|
||
|
// -- Captive portal request were already served.
|
||
|
return;
|
||
|
}
|
||
|
String s = "<!DOCTYPE html><html lang=\"en\"><head><meta name=\"viewport\" content=\"width=device-width, initial-scale=1, user-scalable=no\"/>";
|
||
|
s += "<title>IotWebConf 10 Custom HTML</title></head><body>";
|
||
|
s += FPSTR(CUSTOMHTML_BODY_INNER);
|
||
|
s += "Go to <a href='config'>configure page</a> to change settings.";
|
||
|
s += "</body></html>\n";
|
||
|
|
||
|
server.send(200, "text/html; charset=UTF-8", s);
|
||
|
}
|
||
|
|