|
|
|
/**
|
|
|
|
* Define dialogs to operate sketch binary updates operated by the
|
|
|
|
* AutoConnectUpdate class.
|
|
|
|
* @file AutoConnectUpdatePage.h
|
|
|
|
* @author hieromon@gmail.com
|
|
|
|
* @version 1.0.0
|
|
|
|
* @date 2019-08-15
|
|
|
|
* @copyright MIT license.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _AUTOCONNECTUPDATEPAGE_H
|
|
|
|
#define _AUTOCONNECTUPDATEPAGE_H
|
|
|
|
|
|
|
|
// Define the AUTOCONNECT_URI_UPDATE page to select the sketch binary
|
|
|
|
// for update and order update execution.
|
|
|
|
const AutoConnectUpdateAct::ACElementProp_t AutoConnectUpdateAct::_elmCatalog[] PROGMEM = {
|
|
|
|
{ AC_Element, "binSty", "<style type=\"text/css\">.bins{display:grid;font-size:14px;grid-gap:10px 0;grid-template-columns:1em repeat(4,max-content);overflow-x:auto}.bins input[type=radio]{-moz-appearance:radio;-webkit-appearance:radio;margin:0;vertical-align:middle}.noorder .bins label,.bins span{margin:0 .5em 0 .5em;padding:0;text-align:left}</style>", nullptr },
|
|
|
|
{ AC_Text, "caption", nullptr, nullptr },
|
|
|
|
{ AC_Element, "c1", "<div class=\"bins\">", nullptr },
|
|
|
|
{ AC_Radio, "firmwares", nullptr, nullptr },
|
|
|
|
{ AC_Element, "c1", "</div>", nullptr },
|
|
|
|
{ AC_Submit, "update", "UPDATE", AUTOCONNECT_URI_UPDATE_ACT }
|
|
|
|
};
|
|
|
|
const AutoConnectUpdateAct::ACPage_t AutoConnectUpdateAct::_pageCatalog PROGMEM = {
|
|
|
|
AUTOCONNECT_URI_UPDATE, "Update", false, AutoConnectUpdateAct::_elmCatalog
|
|
|
|
};
|
|
|
|
|
|
|
|
// Define the AUTOCONNECT_URI_UPDATE_ACT page to display during the
|
|
|
|
// update process.
|
|
|
|
const AutoConnectUpdateAct::ACElementProp_t AutoConnectUpdateAct::_elmProgress[] PROGMEM = {
|
|
|
|
{ AC_Element, "loader", "<style>.loader{border:2px solid #f3f3f3;border-radius:50%;border-top:2px solid #555;width:12px;height:12px;-webkit-animation:spin 1s linear infinite;animation:spin 1s linear infinite}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0)}100%{-webkit-transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}</style>", nullptr },
|
|
|
|
{ AC_Element, "c1", "<div style=\"display:inline-block\">", nullptr },
|
|
|
|
{ AC_Element, "binname", nullptr, nullptr },
|
|
|
|
{ AC_Element, "c2", " from ", nullptr },
|
|
|
|
{ AC_Element, "url", "</dv>", nullptr },
|
|
|
|
{ AC_Element, "c3", "<div id=\"progress\">Updating...<span style=\"display:inline-block;vertical-align:middle;margin-left:7px\">", nullptr },
|
|
|
|
{ AC_Element, "progress_meter", "<meter min=\"0\" />", nullptr },
|
|
|
|
{ AC_Element, "progress_loader", "<div id=\"ld\" />", nullptr },
|
|
|
|
{ AC_Element, "c4", "</span></div>", nullptr },
|
|
|
|
{ AC_Text, "status", nullptr, nullptr },
|
|
|
|
{ AC_Element, "c5", "<script type=\"text/javascript\">var lap,cls;function rd(){clearInterval(lap),location.href=\"" AUTOCONNECT_URI_UPDATE_RESULT "\"}function bar(){var t=new FormData;t.append(\"op\",\"#s\");var e=new XMLHttpRequest;e.timeout=" AUTOCONNECT_STRING_DEPLOY(AUTOCONNECT_UPDATE_TIMEOUT) ",e.open(\"POST\",\"" AUTOCONNECT_URI_UPDATE_PROGRESS "\",!0),e.onreadystatechange=function(){4==e.readyState&&(200==e.status?(cls=!1,lap=setInterval(upd," AUTOCONNECT_STRING_DEPLOY(AUTOCONNECT_UPDATE_INTERVAL) ")):document.getElementById(\"status\").textContent=\"Could not start (\"+e.status+\"): \"+e.responseText)},e.send(t)}function upd(){if(!cls){var t=new XMLHttpRequest;t.onload=function(){var t=this.responseText.split(\",\");\"#s\"==t[0]?(window.setTimeout(rd()," AUTOCONNECT_STRING_DEPLOY(AUTOCONNECT_UPDATE_DURATION) ")", nullptr },
|
|
|
|
{ AC_Element, "enable_loader", ",document.getElementById(\"ld\").className=\"loader\"", nullptr },
|
|
|
|
{ AC_Element, "c6", "):\"#e\"==t[0]?(cls=!0,rd()):\"#p\"==t[0]&&incr(t[1])},t.onerror=function(){console.log(\"http err:%d %s\",t.status,t.responseText)},t.open(\"GET\",\"" AUTOCONNECT_URI_UPDATE_PROGRESS "\",!0),t.send()}}function incr(t){", nullptr },
|
|
|
|
{ AC_Element, "inprogress_meter", "var e=t.split(\":\"),n=document.getElementById(\"progress\").getElementsByTagName(\"meter\");n[0].setAttribute(\"value\",e[0]),n[0].setAttribute(\"max\",e[1])", nullptr },
|
|
|
|
{ AC_Element, "c7", "}window.onload=bar;</script>", nullptr }
|
|
|
|
};
|
|
|
|
const AutoConnectUpdateAct::ACPage_t AutoConnectUpdateAct::_pageProgress PROGMEM = {
|
|
|
|
AUTOCONNECT_URI_UPDATE_ACT, "Update", false, AutoConnectUpdateAct::_elmProgress
|
|
|
|
};
|
|
|
|
|
|
|
|
// Definition of the AUTOCONNECT_URI_UPDATE_RESULT page to notify update results
|
|
|
|
const AutoConnectUpdateAct::ACElementProp_t AutoConnectUpdateAct::_elmResult[] PROGMEM = {
|
|
|
|
{ AC_Text, "status", nullptr, nullptr },
|
|
|
|
{ AC_Element, "restart", "<script type=\"text/javascript\">window.onload=function(){var e=new FormData;e.append(\"op\",\"#r\");var o=new XMLHttpRequest;o.timeout=" AUTOCONNECT_STRING_DEPLOY(AUTOCONNECT_UPDATE_TIMEOUT) ",o.onloadend=function(){setTimeout(\"location.href='" AUTOCONNECT_HOMEURI "'\"," AUTOCONNECT_STRING_DEPLOY(AUTOCONNECT_UPDATE_WAITFORREBOOT) ")},o.open(\"POST\",\"" AUTOCONNECT_URI_UPDATE_PROGRESS "\",!0),o.send(e)};</script>", nullptr }
|
|
|
|
};
|
|
|
|
const AutoConnectUpdateAct::ACPage_t AutoConnectUpdateAct::_pageResult PROGMEM = {
|
|
|
|
AUTOCONNECT_URI_UPDATE_RESULT, "Update", false, AutoConnectUpdateAct::_elmResult
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // _AUTOCONNECTUPDATEPAGE_H
|