GyverPortal

4LDIY

✩✩✩✩✩✩✩
17 Июн 2022
9
0
@Олег Поляков, Мне сложно с этим разобраться, можно чуть подробнее, как это в конструкторе будет выглядеть и в коде. Буду признателен
 

Олег Поляков

★✩✩✩✩✩✩
18 Янв 2022
17
13
www.1812.ru
@4LDIY,
пишем кастом-код и вставляем его в html-страницу.
C++:
String cl;
BUILD_BEGIN(cl);
add.THEME(GP_LIGHT);
add.PAGE_BEGIN();
add.PAGE_BLOCK_BEGIN();

cl += F("<script type=\"application/javascript\" language=\"javascript\"");
cl += F("setTimeout(function(){location.reload();},1000);");
cl += F("</script>");

add.PAGE_BLOCK_END();
add.PAGE_END();
BUILD_END();
В переменной cl поместил скрипт, который перезагрузит страницу через секунду.
Теперь вам осталось только написать свой обработчик событий и вставить его код в переменную cl.
 

4LDIY

✩✩✩✩✩✩✩
17 Июн 2022
9
0
@Олег Поляков, Ладно, спасибо за помощь, я понял что нифига не понял. Буду ждать обновление gyverportal, может что для меня нужное появится.
 

aidar_i

✩✩✩✩✩✩✩
1 Май 2021
18
6
@Олег Поляков, Ладно, спасибо за помощь, я понял что нифига не понял. Буду ждать обновление gyverportal, может что для меня нужное появится.
Вставьте в GiverPortal.h
C++:
  void UPDATE(const char* value) {
        *_gp_sptr += F("<meta http-equiv=\"Refresh" );
        *_gp_sptr += "\" content=\"";
        *_gp_sptr += value;
        *_gp_sptr += F("\">\n");
    }
В скетче в buld()
if(en_upd) add.Update(Период в секундах);
Портал запускайте не в сетап, а в лооп так:
bool fl_b= 1; в декларе
в лооп
C++:
  if (en_start) {
    if (fl_b) {
      fl_b = 0;
      portal.attachBuild(build);
      portal.start();
    }
  }
  else fl_b = 1;
  portal.tick();
в момент включения en_upd подайте отрицательный импульс на en_start длительностью 1 цикл , чтобы портал перезагрузился, чтобы перестроить страницу.
Используя конструкцию в лооп я даже на ходу меняю Тему черную на светлую и обратно через кнопку субмит.
в буилд() добавил:
C++:
   if(theme_dark) add.THEME(GP_DARK);
    else add.THEME(GP_LIGHT);
Сюда theme_dark подаю 1 или 0, с кнопки субмит.
C++:
  if (portal.form())
    {
            if (portal.form("/update"))
        {
            if (theme_dark == LOW) theme_dark = HIGH;
            else theme_dark = LOW;
        }
    }
Вот так можно ещё сделать портал
Снимок_2022_06_23_21_23_54_590.png
 
Изменено:

4LDIY

✩✩✩✩✩✩✩
17 Июн 2022
9
0
@aidar_i, спасибо

А на есп32 пробовал кто AJAX значения менять на странице? У меня страница не может получить значение net::ERR_EMPTY_RESPONSE, хотя на 8266 работало. (я в курсе что Гувер на гитхабе написал о есп32)

Сам отвечу. На есп32 не возвращает значение server.argName(0) в portal.h.
C++:
    // вернёт true, если был клик по указанному элементу (кнопка, чекбокс, свитч, слайдер, селектор)
    bool click(const char* name) {
        return _clickF ? server.argName(0).equals(name) : 0;
    }
Библу переделал под себя, у меня теперь работает.
Насчет перезагрузки страницы с сервера
C++:
void AJAX_UPDATE(const char* list, int prd = 1000) { // Код страницы,  отправка запросов
        *_gp_sptr += F("<script>setInterval(function(){\n");
        *_gp_sptr += "var elms=[";
        char buf[strlen(list) + 1];
        strcpy(buf, list);
        char* str = buf;
        splitList(NULL);
        while ((str = splitList(buf)) != NULL) {
            *_gp_sptr += "'";
            if (str[0] == ' ') *_gp_sptr += (str + 1);
            else *_gp_sptr += str;
            *_gp_sptr += "',";
        }
        *_gp_sptr += F("];\n"
        "elms.forEach(function(elm){\n"
        "var xhttp=new XMLHttpRequest();\n"
        "xhttp.onreadystatechange=function(){\n"
        "if(this.readyState==4&&this.status==200){\n"
        "var resp=this.responseText;\n"
        "var item=document.getElementById(elm);\n"
        "if(elm == \"ResetWeb\" && resp == 1){location.reload();}\n"
        "else{"
        "if (elm == \"ResetWeb\" && resp == 0){}else{"
        "if(item.type==\"checkbox\"||item.type==\"radio\")item.checked=Number(resp);\n"
        "else if(item.type==undefined)item.innerHTML=resp;\n"
        "else item.value=resp;}\n"
        "}}};xhttp.open(\"GET\",\"GP_update\"+elm,true);xhttp.send();});},");
        *_gp_sptr += prd;
        *_gp_sptr += F(");</script>\n");
    }
было добавлено значение ResetWeb и , для себя, убрал вопросик после GP_update.
Теперь в конструкторе это выглядит так
C++:
add.AJAX_UPDATE(PSTR("var1, var2, var3, var4, var5, var6, ResetWeb"),1000);
На запрос обновиться компоненту ResetWeb отвечаем либо 0 либо 1, 0 - ни чего не делаем, 1 перезагрузить страницу. Выставляем флаг, о том что там нужно перезагрузиться, и ждем запроса от страницы
C++:
if (portal.update()){
    if (portal.update("ResetWeb")){
        if(flag==true){                     
          portal.answer(String(1)); // перезагрузит страницу
          flag = false;             // сброс флага
         } else{
          portal.answer(String(0)); //не перезагружать страницу
        }
    }
    if (portal.update("var1")){}
}
 
Изменено: