2020-09-02 22:34:49 +03:00
|
|
|
#include "ItemsList.h"
|
|
|
|
|
|
|
|
|
|
#include "Utils\StringUtils.h"
|
|
|
|
|
|
|
|
|
|
static const char* firstLine PROGMEM = "Тип элемента;Id;Виджет;Имя вкладки;Имя виджета;Позиция виджета";
|
|
|
|
|
|
|
|
|
|
void addItem(String name) {
|
|
|
|
|
String item = readFile("items/" + name + ".txt", 1024);
|
|
|
|
|
name = deleteToMarkerLast(name, "-");
|
2020-09-04 15:35:35 +03:00
|
|
|
item.replace("id", name + "-" + String(getNewElementNumber("id.txt")));
|
2020-09-02 22:34:49 +03:00
|
|
|
item.replace("order", String(getNewElementNumber("order.txt")));
|
2020-09-04 15:35:35 +03:00
|
|
|
if (item.indexOf("pin") != -1) { //all cases (random pins from available)
|
2020-09-02 22:34:49 +03:00
|
|
|
item.replace("pin", "pin[" + String(getFreePinAll()) + "]");
|
2020-09-04 00:35:38 +03:00
|
|
|
} else if (item.indexOf("gol") != -1) { //analog
|
|
|
|
|
item.replace("gol", "pin[" + String(getFreePinAnalog()) + "]");
|
|
|
|
|
} else if (item.indexOf("cin") != -1) { //ultrasonic
|
|
|
|
|
item.replace("cin", "pin[" + String(getFreePinAll()) + "," + String(getFreePinAll()) + "]");
|
2020-09-04 15:35:35 +03:00
|
|
|
} else if (item.indexOf("sal") != -1) { //dallas
|
2020-09-04 00:35:38 +03:00
|
|
|
item.replace("sal", "pin[2]");
|
2020-09-04 15:35:35 +03:00
|
|
|
} else if (item.indexOf("thd") != -1) { //dht11/22
|
|
|
|
|
item.replace("thd", "pin[2]");
|
2020-09-02 22:34:49 +03:00
|
|
|
}
|
2020-09-04 00:35:38 +03:00
|
|
|
|
2020-09-02 22:34:49 +03:00
|
|
|
item.replace("\r\n", "");
|
|
|
|
|
item.replace("\r", "");
|
|
|
|
|
item.replace("\n", "");
|
|
|
|
|
addFile(DEVICE_CONFIG_FILE, "\n" + item);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void delAllItems() {
|
|
|
|
|
removeFile(DEVICE_CONFIG_FILE);
|
|
|
|
|
addFile(DEVICE_CONFIG_FILE, String(firstLine));
|
|
|
|
|
removeFile("id.txt");
|
|
|
|
|
removeFile("order.txt");
|
|
|
|
|
removeFile("pins.txt");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
uint8_t getNewElementNumber(String file) {
|
|
|
|
|
uint8_t number = readFile(file, 100).toInt();
|
|
|
|
|
number++;
|
|
|
|
|
removeFile(file);
|
|
|
|
|
addFile(file, String(number));
|
|
|
|
|
return number;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
uint8_t getFreePinAll() {
|
|
|
|
|
#ifdef ESP8266
|
|
|
|
|
uint8_t pins[] = {0, 12, 13, 14, 15, 16, 1, 2, 3, 4, 5};
|
|
|
|
|
#endif
|
|
|
|
|
#ifdef ESP32
|
|
|
|
|
uint8_t pins[] = {0, 12, 13, 14, 15, 16, 1, 2, 3, 4, 5};
|
|
|
|
|
#endif
|
|
|
|
|
uint8_t array_sz = sizeof(pins) / sizeof(pins[0]);
|
|
|
|
|
uint8_t i = getNewElementNumber("pins.txt");
|
|
|
|
|
if (i < array_sz) {
|
|
|
|
|
return pins[i];
|
|
|
|
|
} else {
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
uint8_t getFreePinAnalog() {
|
|
|
|
|
#ifdef ESP8266
|
|
|
|
|
return 0;
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//void do_getJsonListFromCsv() {
|
|
|
|
|
// if (getJsonListFromCsvFlag) {
|
|
|
|
|
// getJsonListFromCsvFlag = false;
|
|
|
|
|
// removeFile("items/items.json");
|
|
|
|
|
// addFile("items/items.json", getJsonListFromCsv(DEVICE_CONFIG_FILE, 1));
|
|
|
|
|
// }
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//String getJsonListFromCsv(String csvFile, int colum) {
|
|
|
|
|
// File configFile = LittleFS.open("/" + csvFile, "r");
|
|
|
|
|
// if (!configFile) {
|
|
|
|
|
// return "error";
|
|
|
|
|
// }
|
|
|
|
|
// configFile.seek(0, SeekSet);
|
|
|
|
|
//
|
|
|
|
|
// String outJson = "{}";
|
|
|
|
|
//
|
|
|
|
|
// int count = -1;
|
|
|
|
|
//
|
|
|
|
|
// while (configFile.position() != configFile.size()) {
|
|
|
|
|
// count++;
|
|
|
|
|
// String item = configFile.readStringUntil('\n');
|
|
|
|
|
// if (count > 0) {
|
|
|
|
|
// String line = selectFromMarkerToMarker(item, ";", colum);
|
|
|
|
|
// jsonWriteStr(outJson, line, line);
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// configFile.close();
|
|
|
|
|
// csvFile = "";
|
|
|
|
|
// return outJson;
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//void do_delElement() {
|
|
|
|
|
// if (delElementFlag) {
|
|
|
|
|
// delElementFlag = false;
|
|
|
|
|
// delElement(itemsFile, itemsLine);
|
|
|
|
|
// }
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//void delElement(String _itemsFile, String _itemsLine) {
|
|
|
|
|
// File configFile = LittleFS.open("/" + _itemsFile, "r");
|
|
|
|
|
// if (!configFile) {
|
|
|
|
|
// return;
|
|
|
|
|
// }
|
|
|
|
|
// configFile.seek(0, SeekSet);
|
|
|
|
|
// String finalConf;
|
|
|
|
|
// int count = -1;
|
|
|
|
|
// while (configFile.position() != configFile.size()) {
|
|
|
|
|
// count++;
|
|
|
|
|
// String item = configFile.readStringUntil('\n');
|
|
|
|
|
// Serial.print(_itemsLine);
|
|
|
|
|
// Serial.print(" ");
|
|
|
|
|
// Serial.println(count);
|
|
|
|
|
// if (count != _itemsLine.toInt()) {
|
|
|
|
|
// if (count == 0) {
|
|
|
|
|
// finalConf += item;
|
|
|
|
|
// } else {
|
|
|
|
|
// finalConf += "\n" + item;
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// removeFile(_itemsFile);
|
|
|
|
|
// addFile(_itemsFile, finalConf);
|
|
|
|
|
// Serial.println(finalConf);
|
|
|
|
|
// itemsFile = "";
|
|
|
|
|
// itemsLine = "";
|
|
|
|
|
// configFile.close();
|
|
|
|
|
//}
|