Merge branch 'develop' of ssh://git.lab-ouest.org:8022/Epitech/T-IOT-901_convoyor into feat/main-algo
# Conflicts: # config.ini # include/Program.h # lib/NFC/src/NfcReader.cpp # src/Program.cpp
This commit is contained in:
commit
f64264631e
5
.vscode/settings.json
vendored
Normal file
5
.vscode/settings.json
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
{
|
||||||
|
"files.associations": {
|
||||||
|
"new": "cpp"
|
||||||
|
}
|
||||||
|
}
|
18
config.ini
18
config.ini
@ -14,9 +14,7 @@ build_flags =
|
|||||||
-D MONITOR_SPEED=${config.monitor_speed}
|
-D MONITOR_SPEED=${config.monitor_speed}
|
||||||
; DO NOT TOUCH --- END
|
; DO NOT TOUCH --- END
|
||||||
-D WAITING_WIFI_DELAY=1000
|
-D WAITING_WIFI_DELAY=1000
|
||||||
|
-D TIMEZONE=\"Europe/Paris\"
|
||||||
-D CONVOYER_LEN=150 ;mm
|
|
||||||
|
|
||||||
;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;
|
||||||
;;; stepper config ;;;
|
;;; stepper config ;;;
|
||||||
;;;;;;;;;;;;;;;;;;;;;;
|
;;;;;;;;;;;;;;;;;;;;;;
|
||||||
@ -25,7 +23,17 @@ build_flags =
|
|||||||
;-D STEPER_PAS=755.906 ; = 65mm
|
;-D STEPER_PAS=755.906 ; = 65mm
|
||||||
-D STEPER_PAS=58 ; = 5mm
|
-D STEPER_PAS=58 ; = 5mm
|
||||||
-D STEPER_SPEED=1000 ; 12000
|
-D STEPER_SPEED=1000 ; 12000
|
||||||
|
;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
;;; App config ;;;
|
||||||
|
;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
-D APP_TITLE=\"Warehouse\"
|
||||||
|
-D APP_VERSION=\"1.0\"
|
||||||
; nfc addr
|
; nfc addr
|
||||||
-D NFC_ADDR=0x28
|
-D NFC_ADDR=0x28
|
||||||
|
;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
;;; Servo config ;;;
|
||||||
|
;;;;;;;;;;;;;;;;;;;;;;
|
||||||
|
-D RIGHT_POS=18
|
||||||
|
-D MIDDLE_POS=32
|
||||||
|
-D LEFT_POS=52
|
||||||
|
-D CONVOYER_LEN=150 ;mm
|
||||||
|
@ -4,7 +4,8 @@ build_flags =
|
|||||||
-D API_LIST_PRODUCT_URL=\"/products/\"
|
-D API_LIST_PRODUCT_URL=\"/products/\"
|
||||||
-D API_GET_PRODUCT_URL=\"/products/{id}/\"
|
-D API_GET_PRODUCT_URL=\"/products/{id}/\"
|
||||||
-D API_GET_PRODUCT_STOCK_URL=\"/products/{id}/stock/\"
|
-D API_GET_PRODUCT_STOCK_URL=\"/products/{id}/stock/\"
|
||||||
|
-D API_GET_PRODUCT_FACTORY_ID=\"/products\"
|
||||||
-D API_LIST_WAREHOUSE_URL=\"/warehouses/\"
|
-D API_LIST_WAREHOUSE_URL=\"/warehouses/\"
|
||||||
-D API_LIST_STOCKS_MOVEMENTS_URL=\"/stockmovements/?sortfield=t.rowid\"
|
-D API_LIST_STOCKS_MOVEMENTS_URL=\"/stockmovements/?sortfield=t.rowid\"
|
||||||
-D API_CREATE_STOCKS_MOVEMENTS_URL=\"/stockmovements/\"
|
-D API_CREATE_STOCKS_MOVEMENTS_URL=\"/stockmovements/\"
|
||||||
-D API_MAX_JSON_SIZE=4096
|
-D API_MAX_JSON_SIZE=6536
|
||||||
|
@ -2,11 +2,10 @@
|
|||||||
#define PROGRAM_H
|
#define PROGRAM_H
|
||||||
|
|
||||||
#include "DolibarrClient.h"
|
#include "DolibarrClient.h"
|
||||||
#include "GRBL.h"
|
|
||||||
#include "NfcReader.h"
|
|
||||||
#include <Arduino.h>
|
|
||||||
#include <M5Stack.h>
|
#include <M5Stack.h>
|
||||||
// #include <vector>
|
#include "ServoMotorComponent.h"
|
||||||
|
#include "NfcReader.h"
|
||||||
|
#include "GRBL.h"
|
||||||
|
|
||||||
class Program {
|
class Program {
|
||||||
public:
|
public:
|
||||||
@ -19,21 +18,14 @@ public:
|
|||||||
* Program WarehouseGUI loop
|
* Program WarehouseGUI loop
|
||||||
*/
|
*/
|
||||||
void loop();
|
void loop();
|
||||||
|
void checkNfc();
|
||||||
|
void checkServo();
|
||||||
|
void checkWifi();
|
||||||
private:
|
private:
|
||||||
|
|
||||||
DolibarrClient *client;
|
DolibarrClient *client;
|
||||||
|
ServoMotorComponent *servo;
|
||||||
/**
|
NfcReader *nfcReader;
|
||||||
* @brief stepper motor controller
|
|
||||||
*/
|
|
||||||
GRBL *grbl;
|
GRBL *grbl;
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief nfc reader
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
NfcReader* NFC;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
#include <WiFi.h>
|
#include <WiFi.h>
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
#include "M5LCD.h"
|
||||||
|
|
||||||
DolibarrClient::DolibarrClient(struct DolibarrConfig dolibarr_config) : dolibarr(dolibarr_config) {
|
DolibarrClient::DolibarrClient(struct DolibarrConfig dolibarr_config) : dolibarr(dolibarr_config) {
|
||||||
#if defined(DEBUG)
|
#if defined(DEBUG)
|
||||||
@ -29,9 +30,11 @@ int DolibarrClient::login() const {
|
|||||||
HTTPClient *client = this->build_url(API_LOGIN_URL);
|
HTTPClient *client = this->build_url(API_LOGIN_URL);
|
||||||
int httpResponseCode = client->GET();
|
int httpResponseCode = client->GET();
|
||||||
if (httpResponseCode > 0) {
|
if (httpResponseCode > 0) {
|
||||||
StaticJsonDocument<API_MAX_JSON_SIZE> doc;
|
DynamicJsonDocument doc(384);
|
||||||
DeserializationError error = deserializeJson(doc, client->getString().c_str());
|
DeserializationError error = deserializeJson(doc, client->getString().c_str());
|
||||||
if (error) {
|
if (error) {
|
||||||
|
Serial.println("ERROR: ");
|
||||||
|
Serial.println(error.c_str());
|
||||||
delete client;
|
delete client;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -56,23 +59,54 @@ std::vector<models::Product> *DolibarrClient::list_products() const {
|
|||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
models::Product *DolibarrClient::get_product_by_id(const char* id_product) const {
|
models::Product DolibarrClient::get_product_by_factory_id(const char* factory_id) const {
|
||||||
HTTPClient *client = this->build_url(replace_id(API_GET_PRODUCT_URL, id_product).c_str());
|
HTTPClient *client = this->build_url(replace_id("/products?sortorder=ASC&limit=1&sqlfilters=(t.accountancy_code_sell:like:'{id}')", factory_id).c_str());
|
||||||
if (client->GET() == HTTP_CODE_OK) {
|
if (client->GET() == HTTP_CODE_OK) {
|
||||||
StaticJsonDocument<API_MAX_JSON_SIZE> doc;
|
DynamicJsonDocument doc(6144);
|
||||||
DeserializationError error = deserializeJson(doc, client->getString().c_str());
|
DeserializationError error = deserializeJson(doc, client->getString().c_str());
|
||||||
if (error) {
|
if (error) {
|
||||||
Serial.println("ERROR: ");
|
Serial.println("ERROR: ");
|
||||||
Serial.println(error.c_str());
|
Serial.println(error.c_str());
|
||||||
|
delete client;
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
for (auto obj : doc.as<JsonArray>()) {
|
||||||
|
models::Product product;
|
||||||
|
product.date_creation = obj["date_creation"].as<std::string>();
|
||||||
|
product.id = obj["id"].as<std::string>();
|
||||||
|
product.entity = obj["entity"].as<std::string>();
|
||||||
|
product.stock_reel = obj["stock_reel"].as<std::string>();
|
||||||
|
product.label = obj["label"].as<std::string>();
|
||||||
|
product.accountancy_code_sell = obj["accountancy_code_sell"].as<std::string>();
|
||||||
|
product.accountancy_code_sell_export = obj["accountancy_code_sell_export"].as<std::string>();
|
||||||
|
product.fk_default_warehouse = obj["fk_default_warehouse"].as<std::string>();
|
||||||
|
delete client;
|
||||||
|
return product;
|
||||||
|
}
|
||||||
|
delete client;
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
delete client;
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
|
||||||
|
models::Product *DolibarrClient::get_product_by_id(const char* id_product) const {
|
||||||
|
HTTPClient *client = this->build_url(replace_id(API_GET_PRODUCT_URL, id_product).c_str());
|
||||||
|
if (client->GET() == HTTP_CODE_OK) {
|
||||||
|
DynamicJsonDocument doc(6144);
|
||||||
|
DeserializationError error = deserializeJson(doc, client->getString().c_str());
|
||||||
|
if (error) {
|
||||||
delete client;
|
delete client;
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
auto *product = new models::Product();
|
auto *product = new models::Product();
|
||||||
product->date_creation = doc["date_creation"];
|
product->date_creation = doc["date_creation"].as<std::string>();
|
||||||
product->id = doc["id"];
|
product->id = doc["id"].as<std::string>();
|
||||||
product->entity = doc["entity"];
|
product->entity = doc["entity"].as<std::string>();
|
||||||
product->stock_reel = doc["stock_reel"];
|
product->stock_reel = doc["stock_reel"].as<std::string>();
|
||||||
product->label = doc["label"];
|
product->label = doc["label"].as<std::string>();
|
||||||
|
product->accountancy_code_sell = doc["accountancy_code_sell"].as<std::string>();
|
||||||
|
product->accountancy_code_sell_export = doc["accountancy_code_sell_export"].as<std::string>();
|
||||||
delete client;
|
delete client;
|
||||||
return product;
|
return product;
|
||||||
}
|
}
|
||||||
@ -83,7 +117,7 @@ models::Product *DolibarrClient::get_product_by_id(const char* id_product) const
|
|||||||
std::vector<models::Warehouse> *DolibarrClient::list_warehouse() const {
|
std::vector<models::Warehouse> *DolibarrClient::list_warehouse() const {
|
||||||
HTTPClient *client = this->build_url(API_LIST_WAREHOUSE_URL);
|
HTTPClient *client = this->build_url(API_LIST_WAREHOUSE_URL);
|
||||||
if (client->GET() == HTTP_CODE_OK) {
|
if (client->GET() == HTTP_CODE_OK) {
|
||||||
StaticJsonDocument<API_MAX_JSON_SIZE> doc;
|
DynamicJsonDocument doc(8192);
|
||||||
DeserializationError error = deserializeJson(doc, client->getString().c_str());
|
DeserializationError error = deserializeJson(doc, client->getString().c_str());
|
||||||
if (error) {
|
if (error) {
|
||||||
Serial.println("ERROR: ");
|
Serial.println("ERROR: ");
|
||||||
@ -94,7 +128,8 @@ std::vector<models::Warehouse> *DolibarrClient::list_warehouse() const {
|
|||||||
auto *warehouses = new std::vector<models::Warehouse>();
|
auto *warehouses = new std::vector<models::Warehouse>();
|
||||||
for (auto obj : doc.as<JsonArray>()) {
|
for (auto obj : doc.as<JsonArray>()) {
|
||||||
models::Warehouse warehouse = {};
|
models::Warehouse warehouse = {};
|
||||||
warehouse.id = obj["id"];
|
warehouse.id = obj["id"].as<std::string>();
|
||||||
|
warehouse.label = obj["label"].as<std::string>();
|
||||||
warehouses->push_back(warehouse);
|
warehouses->push_back(warehouse);
|
||||||
}
|
}
|
||||||
delete client;
|
delete client;
|
||||||
@ -104,13 +139,15 @@ std::vector<models::Warehouse> *DolibarrClient::list_warehouse() const {
|
|||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
int DolibarrClient::create_movement(models::CreateProductStock &stock) const {
|
int DolibarrClient::create_movement(models::CreateProductStock stock) const {
|
||||||
HTTPClient *client = this->build_url("API_CREATE_STOCKS_MOVEMENTS_URL");
|
HTTPClient *client = this->build_url(API_CREATE_STOCKS_MOVEMENTS_URL);
|
||||||
StaticJsonDocument<API_MAX_JSON_SIZE> doc;
|
DynamicJsonDocument doc(4096);
|
||||||
std::string result;
|
std::string result;
|
||||||
doc["product_id"] = stock.product_id;
|
doc["product_id"] = stock.product_id;
|
||||||
doc["warehouse_id"] = stock.warehouse_id;
|
doc["warehouse_id"] = stock.warehouse_id;
|
||||||
doc["qty"] = stock.qty;
|
doc["qty"] = stock.qty;
|
||||||
|
doc["movementlabel"] = "T-IOT - Warehouse GUI";
|
||||||
|
doc["movementcode"] = "M" + stock.product_id + "-W" + stock.warehouse_id;
|
||||||
serializeJson(doc, result);
|
serializeJson(doc, result);
|
||||||
Serial.println(result.c_str());
|
Serial.println(result.c_str());
|
||||||
if (client->POST(result.c_str()) == HTTP_CODE_OK) {
|
if (client->POST(result.c_str()) == HTTP_CODE_OK) {
|
||||||
@ -122,30 +159,5 @@ int DolibarrClient::create_movement(models::CreateProductStock &stock) const {
|
|||||||
|
|
||||||
int DolibarrClient::initialize_http_client() {
|
int DolibarrClient::initialize_http_client() {
|
||||||
this->httpClient = new HTTPClient();
|
this->httpClient = new HTTPClient();
|
||||||
if (this->login() == 0) {
|
|
||||||
auto* product = this->get_product_by_id("1");
|
|
||||||
if (product == nullptr) {
|
|
||||||
Serial.println("Product is nullptr !");
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
Serial.println("Product label: ");
|
|
||||||
Serial.println(product->label);
|
|
||||||
auto* warehouses = this->list_warehouse();
|
|
||||||
if (warehouses == nullptr) {
|
|
||||||
delete product;
|
|
||||||
Serial.println("Warehouse is nullptr !");
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
Serial.println("Warehouses: ");
|
|
||||||
models::CreateProductStock product_stock = {product->id, warehouses->at(0).id, "1"};
|
|
||||||
this->create_movement(product_stock);
|
|
||||||
for (auto warehouse : *warehouses) {
|
|
||||||
Serial.println(warehouse.id);
|
|
||||||
}
|
|
||||||
delete product;
|
|
||||||
delete warehouses;
|
|
||||||
} else {
|
|
||||||
Serial.println("An Error has occurred while trying to login");
|
|
||||||
}
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
@ -24,7 +24,8 @@ public:
|
|||||||
std::vector<models::Warehouse> *list_warehouse() const;
|
std::vector<models::Warehouse> *list_warehouse() const;
|
||||||
std::vector<models::Product> *list_products() const;
|
std::vector<models::Product> *list_products() const;
|
||||||
models::Product *get_product_by_id(const char* id_product) const;
|
models::Product *get_product_by_id(const char* id_product) const;
|
||||||
int create_movement(models::CreateProductStock &stock) const;
|
models::Product get_product_by_factory_id(const char* uuid) const;
|
||||||
|
int create_movement(models::CreateProductStock stock) const;
|
||||||
private:
|
private:
|
||||||
HTTPClient* httpClient{};
|
HTTPClient* httpClient{};
|
||||||
struct DolibarrConfig dolibarr;
|
struct DolibarrConfig dolibarr;
|
||||||
|
@ -4,35 +4,39 @@
|
|||||||
namespace models {
|
namespace models {
|
||||||
|
|
||||||
struct Product {
|
struct Product {
|
||||||
const char* id;
|
std::string id;
|
||||||
const char* entity;
|
std::string entity;
|
||||||
const char* ref;
|
std::string ref;
|
||||||
const char* status;
|
std::string status;
|
||||||
const char* date_creation;
|
std::string date_creation;
|
||||||
const char* date_modification;
|
std::string date_modification;
|
||||||
const char* label;
|
std::string label;
|
||||||
const char* description;
|
std::string description;
|
||||||
const char* type;
|
std::string type;
|
||||||
const char* price;
|
std::string accountancy_code_sell;
|
||||||
const char* stock_reel;
|
std::string accountancy_code_sell_export;
|
||||||
const char* seuil_stock_alerte;
|
std::string fk_default_warehouse;
|
||||||
const char* desiredstock;
|
std::string price;
|
||||||
|
std::string stock_reel;
|
||||||
|
std::string seuil_stock_alerte;
|
||||||
|
std::string desiredstock;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct ProductStock {
|
struct ProductStock {
|
||||||
const char* id;
|
std::string id;
|
||||||
const char* product_id;
|
std::string product_id;
|
||||||
const char* quantity;
|
std::string quantity;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct CreateProductStock {
|
struct CreateProductStock {
|
||||||
const char* product_id;
|
std::string product_id;
|
||||||
const char* warehouse_id;
|
std::string warehouse_id;
|
||||||
const char* qty;
|
std::string qty;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Warehouse {
|
struct Warehouse {
|
||||||
const char* id;
|
std::string id;
|
||||||
|
std::string label;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
224
lib/M5LCD/src/M5LCD.cpp
Normal file
224
lib/M5LCD/src/M5LCD.cpp
Normal file
@ -0,0 +1,224 @@
|
|||||||
|
#include "M5LCD.h"
|
||||||
|
|
||||||
|
/*
|
||||||
|
* M5LCD classe
|
||||||
|
*/
|
||||||
|
|
||||||
|
M5LCD::M5LCD() : _current_page(0), _logs() , _debug_loc_y(0), _components_status({COMPONENT_KO, COMPONENT_KO, COMPONENT_KO, COMPONENT_KO, COMPONENT_KO}) {
|
||||||
|
this->_product_id = std::string("");
|
||||||
|
this->_product_label = std::string("");
|
||||||
|
this->_last_nfc = std::string("");
|
||||||
|
this->_servo_current_position = std::string("");
|
||||||
|
this->_dolibarr_msg = std::string("");
|
||||||
|
M5.begin();
|
||||||
|
M5.Power.begin();
|
||||||
|
M5.lcd.setBrightness(100);
|
||||||
|
this->update_page();
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::update() {
|
||||||
|
M5.update();
|
||||||
|
if (M5.BtnB.wasReleased() != 0) {
|
||||||
|
this->_current_page = (this->_current_page + 1) % LCD_PAGES;
|
||||||
|
this->update_page();
|
||||||
|
}
|
||||||
|
if (this->_current_page == DEBUG_SCREEN && M5.BtnA.wasReleased() != 0 && this->_debug_loc_y < 0) {
|
||||||
|
this->_debug_loc_y++;
|
||||||
|
this->update_page();
|
||||||
|
}
|
||||||
|
if (this->_current_page == DEBUG_SCREEN && M5.BtnC.wasReleased() != 0) {
|
||||||
|
this->_debug_loc_y--;
|
||||||
|
this->update_page();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::update_page() const {
|
||||||
|
M5.Lcd.clear();
|
||||||
|
switch (this->_current_page) {
|
||||||
|
case 0:
|
||||||
|
this->show_dashboard();
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
this->show_debug();
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
this->show_config();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
this->update_pagination();
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::display_error(const char *str) const {
|
||||||
|
M5.Lcd.setTextColor(WHITE, RED);
|
||||||
|
M5.Lcd.setTextSize(1);
|
||||||
|
M5.Lcd.setCursor(0, 40);
|
||||||
|
M5.Lcd.println(str);
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::display_message(const char *str) const {
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::display_warning(const char *str) const {
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string get_status(AvailableComponentsStatus status) {
|
||||||
|
return status == COMPONENT_OK ? "OK" : "KO";
|
||||||
|
}
|
||||||
|
|
||||||
|
void draw_component_stats(int x, int y, int fx, int fy, int fw, int fh, const char *name, AvailableComponentsStatus status) {
|
||||||
|
M5.Lcd.setTextSize(2);
|
||||||
|
if (status == COMPONENT_OK) {
|
||||||
|
M5.Lcd.setTextColor(WHITE, GREEN);
|
||||||
|
} else {
|
||||||
|
M5.Lcd.setTextColor(WHITE, RED);
|
||||||
|
}
|
||||||
|
if (status == COMPONENT_OK) {
|
||||||
|
M5.Lcd.fillRect(fx, fy, fw, fh, GREEN);
|
||||||
|
} else {
|
||||||
|
M5.Lcd.fillRect(fx, fy, fw, fh, RED);
|
||||||
|
}
|
||||||
|
M5.Lcd.setCursor(x, y);
|
||||||
|
M5.Lcd.printf("%s %s", name, get_status(status).c_str());
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::show_dashboard() const {
|
||||||
|
draw_component_stats(10, 18, 0, 0, 100, 50, "NFC", _components_status.nfc);
|
||||||
|
draw_component_stats(150, 18, 110, 0, 210, 50, "DOLIBARR", _components_status.dolibarr);
|
||||||
|
draw_component_stats(8, 78, 0, 60, 100, 50, "WIFI", _components_status.wifi);
|
||||||
|
draw_component_stats(112, 78, 110, 60, 100, 50, "SERVO", _components_status.servo);
|
||||||
|
draw_component_stats(230, 78, 220, 60, 100, 50, "GRBL", _components_status.grbl);
|
||||||
|
|
||||||
|
M5.Lcd.drawRect(0, 120, 320, 100, BLUE);
|
||||||
|
M5.Lcd.setTextColor(WHITE, BLACK);
|
||||||
|
M5.Lcd.setTextSize(2);
|
||||||
|
if (!this->_last_nfc.empty()) {
|
||||||
|
M5.Lcd.setCursor(10, 130);
|
||||||
|
M5.Lcd.printf("NFC: %s", this->_last_nfc.c_str());
|
||||||
|
}
|
||||||
|
if (!this->_product_id.empty() && !this->_product_label.empty()) {
|
||||||
|
M5.Lcd.setCursor(10, 150);
|
||||||
|
M5.Lcd.printf("Produit: %s - %s", this->_product_label.c_str(), this->_product_id.c_str());
|
||||||
|
}
|
||||||
|
if (!this->_dolibarr_msg.empty()) {
|
||||||
|
M5.Lcd.setCursor(10, 170);
|
||||||
|
M5.Lcd.printf("Produit: %s", this->_last_nfc.c_str());
|
||||||
|
}
|
||||||
|
if (!this->_servo_current_position.empty()) {
|
||||||
|
M5.Lcd.setCursor(10, 190);
|
||||||
|
M5.Lcd.printf("SERVO Posistion: %s", this->_servo_current_position.c_str());
|
||||||
|
}
|
||||||
|
|
||||||
|
M5.Lcd.setTextSize(1);
|
||||||
|
M5.Lcd.setCursor(0, 230);
|
||||||
|
M5.Lcd.printf("%s - %s", APP_TITLE, APP_VERSION);
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::show_debug() const {
|
||||||
|
M5.Lcd.setTextColor(WHITE, BLACK);
|
||||||
|
M5.Lcd.setTextSize(1);
|
||||||
|
int i = 0;
|
||||||
|
for (auto val : this->_logs) {
|
||||||
|
M5.Lcd.setCursor(0, i + (this->_debug_loc_y * 10));
|
||||||
|
M5.Lcd.printf("[%s] - %s", val.get_datetime_format(), val.get_message().c_str());
|
||||||
|
i+=10;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::update_pagination() const {
|
||||||
|
M5.Lcd.setTextSize(1);
|
||||||
|
M5.Lcd.setTextColor(WHITE, BLACK);
|
||||||
|
M5.Lcd.setCursor(302, 230);
|
||||||
|
M5.Lcd.printf("%d/%d", this->_current_page+1, LCD_PAGES);
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::add_log(const char* str) {
|
||||||
|
this->_logs.emplace_back(str);
|
||||||
|
if (this->_current_page == DEBUG_SCREEN) {
|
||||||
|
this->show_debug();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::show_config() const {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
ComponentsStatus M5LCD::get_components() {
|
||||||
|
return this->_components_status;
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::set_wifi_status(AvailableComponentsStatus status) {
|
||||||
|
this->_components_status.wifi = status;
|
||||||
|
this->update_dashboard();
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::set_nfc_status(AvailableComponentsStatus status) {
|
||||||
|
this->_components_status.nfc = status;
|
||||||
|
this->update_dashboard();
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::set_grbl_status(AvailableComponentsStatus status) {
|
||||||
|
this->_components_status.grbl = status;
|
||||||
|
this->update_dashboard();
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::set_servo(AvailableComponentsStatus status) {
|
||||||
|
this->_components_status.servo = status;
|
||||||
|
this->update_dashboard();
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::set_dolibarr_status(AvailableComponentsStatus status) {
|
||||||
|
this->_components_status.dolibarr = status;
|
||||||
|
this->update_dashboard();
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::update_dashboard() const {
|
||||||
|
if (this->_current_page == DASHBOARD_SCREEN) {
|
||||||
|
this->show_dashboard();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void M5LCD::set_dolibarr_message(std::string str) {
|
||||||
|
this->_dolibarr_msg = str;
|
||||||
|
this->update_dashboard();
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::set_nfc_message(std::string str) {
|
||||||
|
this->_last_nfc = str;
|
||||||
|
this->update_dashboard();
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::set_product_id(std::string str) {
|
||||||
|
this->_product_id = str;
|
||||||
|
this->update_dashboard();
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::set_servo_message(std::string str) {
|
||||||
|
this->_servo_current_position = str;
|
||||||
|
this->update_dashboard();
|
||||||
|
}
|
||||||
|
|
||||||
|
void M5LCD::set_product_label(std::string str) {
|
||||||
|
this->_product_label = str;
|
||||||
|
this->update_dashboard();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* LogMessage classe
|
||||||
|
*/
|
||||||
|
|
||||||
|
LogMessage::LogMessage(std::string log) {
|
||||||
|
this->log = log;
|
||||||
|
this->datetime = time(nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string LogMessage::get_message() const {
|
||||||
|
return this->log;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *LogMessage::get_datetime_format() const {
|
||||||
|
void *buff = malloc(20 * sizeof(char));
|
||||||
|
strftime((char*) buff, 20, "%H:%M:%S", localtime(&this->datetime));
|
||||||
|
return (char*) buff;
|
||||||
|
}
|
84
lib/M5LCD/src/M5LCD.h
Normal file
84
lib/M5LCD/src/M5LCD.h
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
#ifndef T_IOT_901_CONVOYOR_M5LCD_H
|
||||||
|
#define T_IOT_901_CONVOYOR_M5LCD_H
|
||||||
|
|
||||||
|
#include <vector>
|
||||||
|
#include <ctime>
|
||||||
|
#include "M5Stack.h"
|
||||||
|
|
||||||
|
#define LCD_PAGES 3
|
||||||
|
#define DASHBOARD_SCREEN 0
|
||||||
|
#define DEBUG_SCREEN 1
|
||||||
|
#define CONFIG_SCREEN 2
|
||||||
|
|
||||||
|
enum AvailableComponentsStatus {
|
||||||
|
COMPONENT_OK,
|
||||||
|
COMPONENT_KO,
|
||||||
|
COMPONENT_MISSING,
|
||||||
|
UNKNOWN_ERROR,
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef struct ComponentsStatus {
|
||||||
|
AvailableComponentsStatus nfc;
|
||||||
|
AvailableComponentsStatus wifi;
|
||||||
|
AvailableComponentsStatus dolibarr;
|
||||||
|
AvailableComponentsStatus servo;
|
||||||
|
AvailableComponentsStatus grbl;
|
||||||
|
} ComponentsStatus;
|
||||||
|
|
||||||
|
typedef struct MessageToShow {
|
||||||
|
const char* message;
|
||||||
|
int color;
|
||||||
|
} MessageToShow;
|
||||||
|
|
||||||
|
class LogMessage {
|
||||||
|
public:
|
||||||
|
LogMessage(std::string log);
|
||||||
|
std::string get_message() const;
|
||||||
|
const char* get_datetime_format() const;
|
||||||
|
private:
|
||||||
|
time_t datetime;
|
||||||
|
std::string log;
|
||||||
|
};
|
||||||
|
|
||||||
|
class M5LCD {
|
||||||
|
public:
|
||||||
|
M5LCD();
|
||||||
|
void display_message(const char* str) const;
|
||||||
|
void display_error(const char* str) const;
|
||||||
|
void display_warning(const char* str) const;
|
||||||
|
void add_log(const char *str);
|
||||||
|
void update();
|
||||||
|
ComponentsStatus get_components();
|
||||||
|
void set_wifi_status(AvailableComponentsStatus status);
|
||||||
|
void set_nfc_status(AvailableComponentsStatus status);
|
||||||
|
void set_grbl_status(AvailableComponentsStatus status);
|
||||||
|
void set_servo(AvailableComponentsStatus status);
|
||||||
|
void set_dolibarr_status(AvailableComponentsStatus status);
|
||||||
|
|
||||||
|
void set_nfc_message(std::string str);
|
||||||
|
void set_dolibarr_message(std::string str);
|
||||||
|
void set_product_label(std::string str);
|
||||||
|
void set_product_id(std::string str);
|
||||||
|
void set_servo_message(std::string str);
|
||||||
|
private:
|
||||||
|
void update_page() const;
|
||||||
|
void show_debug() const;
|
||||||
|
void show_dashboard() const;
|
||||||
|
void show_config() const;
|
||||||
|
void update_pagination() const;
|
||||||
|
void update_dashboard() const;
|
||||||
|
|
||||||
|
int _current_page;
|
||||||
|
int _debug_loc_y;
|
||||||
|
std::vector<LogMessage> _logs;
|
||||||
|
ComponentsStatus _components_status;
|
||||||
|
std::string _last_nfc;
|
||||||
|
std::string _product_label;
|
||||||
|
std::string _product_id;
|
||||||
|
std::string _dolibarr_msg;
|
||||||
|
std::string _servo_current_position;
|
||||||
|
};
|
||||||
|
|
||||||
|
inline M5LCD *lcdScreen;
|
||||||
|
|
||||||
|
#endif //T_IOT_901_CONVOYOR_M5LCD_H
|
@ -23,3 +23,10 @@ String NfcReader::ReadNfc()
|
|||||||
}
|
}
|
||||||
return (this->uid);
|
return (this->uid);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool NfcReader::IsNfcConnected()
|
||||||
|
{
|
||||||
|
Wire.beginTransmission(NFC_ADDR);
|
||||||
|
byte error = Wire.endTransmission();
|
||||||
|
return error == 0;
|
||||||
|
}
|
@ -9,6 +9,7 @@ class NfcReader {
|
|||||||
public:
|
public:
|
||||||
NfcReader(int i2c_adress);
|
NfcReader(int i2c_adress);
|
||||||
~NfcReader() = default;
|
~NfcReader() = default;
|
||||||
|
bool IsNfcConnected();
|
||||||
|
|
||||||
String ReadNfc();
|
String ReadNfc();
|
||||||
|
|
||||||
|
63
lib/ServoMotorComponent/src/ServoMotorComponent.cpp
Normal file
63
lib/ServoMotorComponent/src/ServoMotorComponent.cpp
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
#include "ServoMotorComponent.h"
|
||||||
|
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Functions for setting up the ServoMotor
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor.
|
||||||
|
* Prepares the ServoMotor.
|
||||||
|
*/
|
||||||
|
ServoMotorComponent::ServoMotorComponent(int PIN, unsigned long updatePeriod, float step) {
|
||||||
|
this->PIN = PIN;
|
||||||
|
this->myservo.attach(PIN);
|
||||||
|
this->desiredposition = Position::MIDDLE;
|
||||||
|
this->currentPosition = MIDDLE_POS;
|
||||||
|
this->lastUpTime = millis();
|
||||||
|
this->updatePeriod = updatePeriod;
|
||||||
|
this->step = step;
|
||||||
|
this->myservo.write(this->PIN, this->currentPosition);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the desired position
|
||||||
|
* @desiredPosition: Give desired position
|
||||||
|
*/
|
||||||
|
void ServoMotorComponent::setDesiredPosition(Position desiredPosition) {
|
||||||
|
switch (desiredPosition) {
|
||||||
|
case Position::LEFT:
|
||||||
|
this->desiredposition = LEFT_POS;
|
||||||
|
break;
|
||||||
|
case Position::MIDDLE:
|
||||||
|
this->desiredposition = MIDDLE_POS;
|
||||||
|
break;
|
||||||
|
case Position::RIGHT:
|
||||||
|
this->desiredposition = RIGHT_POS;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Write a new servoMotor position when it's necessary
|
||||||
|
*/
|
||||||
|
void ServoMotorComponent::refresh() {
|
||||||
|
if (this->desiredposition == this->currentPosition
|
||||||
|
|| millis() - this->lastUpTime <= this->updatePeriod) return;
|
||||||
|
|
||||||
|
if (this->currentPosition > this->desiredposition) {
|
||||||
|
this->currentPosition -= this->step;
|
||||||
|
}
|
||||||
|
if (this->currentPosition < this->desiredposition) {
|
||||||
|
this->currentPosition += this->step;
|
||||||
|
}
|
||||||
|
this->lastUpTime = millis();
|
||||||
|
this->myservo.write(this->PIN, this->currentPosition);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ServoMotorComponent::isConnected() {
|
||||||
|
return true;
|
||||||
|
}
|
34
lib/ServoMotorComponent/src/ServoMotorComponent.h
Normal file
34
lib/ServoMotorComponent/src/ServoMotorComponent.h
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
#ifndef SERVOMOTOT_COMPONENT_H
|
||||||
|
#define SERVOMOTOT_COMPONENT_H
|
||||||
|
|
||||||
|
#include <Servo.h>
|
||||||
|
|
||||||
|
enum Position {
|
||||||
|
LEFT,
|
||||||
|
MIDDLE,
|
||||||
|
RIGHT
|
||||||
|
};
|
||||||
|
|
||||||
|
class ServoMotorComponent
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
ServoMotorComponent(int PIN, unsigned long updatePeriod = 100, float step = 0.1);
|
||||||
|
void setDesiredPosition(Position desiredPosition);
|
||||||
|
bool isConnected();
|
||||||
|
void refresh();
|
||||||
|
|
||||||
|
private:
|
||||||
|
int PIN;
|
||||||
|
float currentPosition;
|
||||||
|
float desiredposition;
|
||||||
|
Servo myservo;
|
||||||
|
unsigned long lastUpTime;
|
||||||
|
unsigned long updatePeriod;
|
||||||
|
float step;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif //SERVOMOTOT_COMPONENT_H
|
1
lib/WorldTime/src/WorldTime.cpp
Normal file
1
lib/WorldTime/src/WorldTime.cpp
Normal file
@ -0,0 +1 @@
|
|||||||
|
#include "WorldTime.h"
|
6
lib/WorldTime/src/WorldTime.h
Normal file
6
lib/WorldTime/src/WorldTime.h
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#ifndef T_IOT_901_CONVOYOR_WORLDTIME_H
|
||||||
|
#define T_IOT_901_CONVOYOR_WORLDTIME_H
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif //T_IOT_901_CONVOYOR_WORLDTIME_H
|
@ -55,6 +55,7 @@ lib_deps =
|
|||||||
m5stack/M5Stack@^0.4.5 ; M5 Lib
|
m5stack/M5Stack@^0.4.5 ; M5 Lib
|
||||||
m5stack/M5GFX@^0.1.9 ; M5 Lib pour le LCD
|
m5stack/M5GFX@^0.1.9 ; M5 Lib pour le LCD
|
||||||
m5stack/Module_GRBL_13.2@^0.0.3 ; M5 Lib pour Stepper (GRBL)
|
m5stack/Module_GRBL_13.2@^0.0.3 ; M5 Lib pour Stepper (GRBL)
|
||||||
|
dlloydev/ESP32 ESP32S2 AnalogWrite ; Lib pour le Servo Motor
|
||||||
; example:
|
; example:
|
||||||
; erropix/ESP32 AnalogWrite@0.2
|
; erropix/ESP32 AnalogWrite@0.2
|
||||||
|
|
||||||
|
196
src/Program.cpp
196
src/Program.cpp
@ -1,103 +1,159 @@
|
|||||||
#include "Program.h"
|
#include "Program.h"
|
||||||
#include "Arduino.h"
|
#include "Arduino.h"
|
||||||
|
#include "M5LCD.h"
|
||||||
#include "DolibarrClient.h"
|
#include "DolibarrClient.h"
|
||||||
|
#include "ServoMotorComponent.h"
|
||||||
|
#include "NfcReader.h"
|
||||||
|
#include <Ticker.h>
|
||||||
|
|
||||||
|
uint32_t derniereExecution = 0;
|
||||||
|
const uint32_t intervalle = 1000;
|
||||||
|
std::vector<models::Warehouse> *warehouses;
|
||||||
|
|
||||||
int initialize_wifi(WifiConfig wifi) {
|
int initialize_wifi(WifiConfig wifi) {
|
||||||
|
lcdScreen->add_log("Connecting to the WiFi network...");
|
||||||
WiFiClass::mode(WIFI_STA); //Optional
|
WiFiClass::mode(WIFI_STA); //Optional
|
||||||
WiFi.setSleep(false);
|
WiFi.setSleep(false);
|
||||||
WiFi.begin(wifi.ssid, wifi.password);
|
WiFi.begin(wifi.ssid, wifi.password);
|
||||||
Serial.print("Connecting ");
|
|
||||||
while(WiFiClass::status() != WL_CONNECTED){
|
|
||||||
delay(WAITING_WIFI_DELAY);
|
|
||||||
Serial.print(".");
|
|
||||||
}
|
|
||||||
Serial.println("Connected to the WiFi network");
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Program::checkNfc() {
|
||||||
|
if (this->nfcReader->IsNfcConnected() && lcdScreen->get_components().nfc != COMPONENT_OK) {
|
||||||
|
lcdScreen->set_nfc_status(COMPONENT_OK);
|
||||||
|
lcdScreen->add_log("NFC component connected !");
|
||||||
|
Serial.println("NFC IS CONNECTED !");
|
||||||
|
} else if (!this->nfcReader->IsNfcConnected() && lcdScreen->get_components().nfc == COMPONENT_OK) {
|
||||||
|
lcdScreen->set_nfc_status(COMPONENT_KO);
|
||||||
|
lcdScreen->add_log("NFC component disconnected !");
|
||||||
|
Serial.println("NFC NOT CONNECTED !");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Program::checkServo() {
|
||||||
|
if (this->servo->isConnected() && lcdScreen->get_components().servo != COMPONENT_OK) {
|
||||||
|
lcdScreen->set_servo(COMPONENT_OK);
|
||||||
|
lcdScreen->add_log("SERVO component connected !");
|
||||||
|
Serial.println("SERVO IS CONNECTED !");
|
||||||
|
} else if (!this->servo->isConnected() && lcdScreen->get_components().servo == COMPONENT_OK) {
|
||||||
|
lcdScreen->set_servo(COMPONENT_KO);
|
||||||
|
lcdScreen->add_log("SERVO component disconnected !");
|
||||||
|
Serial.println("SERVO NOT CONNECTED !");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Program::checkWifi() {
|
||||||
|
if (WiFiClass::status() == WL_CONNECTED && lcdScreen->get_components().wifi != COMPONENT_OK) {
|
||||||
|
lcdScreen->add_log("Connected to the WiFi network");
|
||||||
|
lcdScreen->set_wifi_status(COMPONENT_OK);
|
||||||
|
struct DolibarrConfig dolibarr = {DOLIBARR_URL, DOLIBARR_API_TOKEN};
|
||||||
|
this->client = new DolibarrClient(dolibarr);
|
||||||
|
warehouses = this->client->list_warehouse();
|
||||||
|
if (warehouses != nullptr) {
|
||||||
|
lcdScreen->add_log("Warehouses found !");
|
||||||
|
lcdScreen->set_dolibarr_status(COMPONENT_OK);
|
||||||
|
for (auto &ware : *warehouses) {
|
||||||
|
char buffer[50];
|
||||||
|
sprintf(buffer, "+ Warehouse '%s' (%s)", ware.label.c_str(), ware.id.c_str());
|
||||||
|
lcdScreen->add_log(buffer);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
lcdScreen->add_log("Warehouse not found");
|
||||||
|
lcdScreen->set_dolibarr_status(COMPONENT_KO);
|
||||||
|
}
|
||||||
|
} else if (WiFiClass::status() != WL_CONNECTED && lcdScreen->get_components().wifi == COMPONENT_OK) {
|
||||||
|
lcdScreen->add_log("Wifi signal lost, reconnecting...");
|
||||||
|
lcdScreen->set_wifi_status(COMPONENT_KO);
|
||||||
|
lcdScreen->set_dolibarr_status(COMPONENT_KO);
|
||||||
|
struct WifiConfig wifi_c = {WIFI_SSID, WIFI_PASSWORD};
|
||||||
|
initialize_wifi(wifi_c);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Program::Program() {
|
Program::Program() {
|
||||||
Serial.begin(MONITOR_SPEED);
|
Serial.begin(MONITOR_SPEED);
|
||||||
struct WifiConfig wifi_c = {WIFI_SSID, WIFI_PASSWORD};
|
Wire.begin();
|
||||||
struct DolibarrConfig dolibarr = {DOLIBARR_URL, DOLIBARR_API_TOKEN};
|
delay(1000);
|
||||||
initialize_wifi(wifi_c);
|
lcdScreen = new M5LCD();
|
||||||
this->client = new DolibarrClient(dolibarr);
|
lcdScreen->add_log("Initialize M5LCD component....");
|
||||||
|
this->nfcReader = new NfcReader(NFC_ADDR);
|
||||||
// initialisation GRBL
|
this->servo = new ServoMotorComponent(2, 1, 1);
|
||||||
this->grbl = new GRBL(STEPMOTOR_I2C_ADDR);
|
this->grbl = new GRBL(STEPMOTOR_I2C_ADDR);
|
||||||
Wire.begin(21, 22);
|
Wire.begin(21, 22);
|
||||||
grbl->init(STEPER_SPEED, STEPER_PAS, STEPER_ACC);
|
grbl->init(STEPER_SPEED, STEPER_PAS, STEPER_ACC);
|
||||||
|
struct WifiConfig wifi_c = {WIFI_SSID, WIFI_PASSWORD};
|
||||||
this->NFC = new NfcReader(NFC_ADDR);
|
initialize_wifi(wifi_c);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Program::loop() {
|
void Program::loop() {
|
||||||
// if(this->grbl->)
|
lcdScreen->update();
|
||||||
// this->grbl->mouveForward(5); //TODO: réglé pour qu'il avance de la bonne distance
|
|
||||||
// String nfcIn = "0"; // TODO: si le lecteur envoie qqc
|
|
||||||
// //TODO: refrech servo
|
|
||||||
// if(nfcIn !="0"){
|
|
||||||
// //envoyer sur dolibard
|
|
||||||
// this->NfcIDs->push_back(nfcIn);
|
|
||||||
// }
|
|
||||||
// if(this->NfcIDs->size() > 0){
|
|
||||||
// }
|
|
||||||
|
|
||||||
//algo V1
|
uint32_t maintenant = millis();
|
||||||
//je lis la valeur NFC
|
if (maintenant - derniereExecution >= intervalle) {
|
||||||
String nfcId = this->NFC->ReadNfc();
|
this->checkServo();
|
||||||
|
this->checkNfc();
|
||||||
|
this->checkWifi();
|
||||||
|
derniereExecution = maintenant;
|
||||||
|
}
|
||||||
|
this->servo->refresh();
|
||||||
|
|
||||||
|
String nfcId = this->nfcReader->ReadNfc();
|
||||||
//si qqc
|
//si qqc
|
||||||
if(nfcId != "0"){
|
if(nfcId != "0"){
|
||||||
|
if (lcdScreen->get_components().wifi != COMPONENT_OK) {
|
||||||
|
lcdScreen->add_log("Wifi not connected !");
|
||||||
|
lcdScreen->set_nfc_message("Cannot send wifi request !");
|
||||||
|
return;
|
||||||
|
}
|
||||||
//j'arrète le stepper
|
//j'arrète le stepper
|
||||||
//this->grbl->stop(); //FIXME: implemente
|
//this->grbl->stop(); //FIXME: implemente
|
||||||
//j'affiche le tag lue
|
//j'affiche le tag lue
|
||||||
Serial.print("new colis in comming : ");
|
Serial.print("new colis in comming : ");
|
||||||
Serial.println(nfcId);
|
lcdScreen->add_log("new colis detected: ");
|
||||||
//je demande a dolibard ou j'envoie
|
lcdScreen->add_log(nfcId.c_str());
|
||||||
Serial.println("Demande a dolibard");
|
lcdScreen->set_nfc_message(nfcId.c_str());
|
||||||
delay(500);// TODO: remove mock
|
auto product = this->client->get_product_by_factory_id(nfcId.c_str());
|
||||||
//j'envoie au servo la commande
|
Serial.printf("Product: %s\n%s", product.label.c_str(), product.accountancy_code_sell_export.c_str());
|
||||||
Serial.print("Servo : ");
|
lcdScreen->set_product_label(product.label);
|
||||||
Serial.println("Droite");
|
lcdScreen->set_product_id(product.id);
|
||||||
delay(500);// TODO: remove mock
|
/*if (product.fk_default_warehouse == product.accountancy_code_sell_export) {
|
||||||
//j'avance le moteur jusqu'a X (a definir)
|
Serial.printf("Product already in the good warehouse !\n");
|
||||||
|
return;
|
||||||
|
}*/
|
||||||
|
auto ware = std::find_if(warehouses->begin(), warehouses->end(), [&product](models::Warehouse w) {return w.id == product.accountancy_code_sell_export;});
|
||||||
|
if (ware.base() == nullptr) {
|
||||||
|
Serial.printf("Warehouse not found !\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Serial.printf("Product need to go to warehouse %s\n", ware->label.c_str());
|
||||||
|
this->client->create_movement(models::CreateProductStock{
|
||||||
|
product.id,
|
||||||
|
product.fk_default_warehouse,
|
||||||
|
"-1"
|
||||||
|
});
|
||||||
|
if (this->client->create_movement(models::CreateProductStock{
|
||||||
|
product.id,
|
||||||
|
ware->id,
|
||||||
|
"1"
|
||||||
|
}) == 0) {
|
||||||
|
Serial.printf("Movement created !\n");
|
||||||
|
} else {
|
||||||
|
Serial.printf("Movement cannot be created !\n");
|
||||||
|
}
|
||||||
|
if (ware->id == "1") {
|
||||||
|
this->servo->setDesiredPosition(Position::RIGHT);
|
||||||
|
lcdScreen->set_servo_message("RIGHT");
|
||||||
|
} else if (ware->id == "2") {
|
||||||
|
this->servo->setDesiredPosition(Position::LEFT);
|
||||||
|
lcdScreen->set_servo_message("LEFT");
|
||||||
|
} else if (ware->id == "3") {
|
||||||
|
this->servo->setDesiredPosition(Position::MIDDLE);
|
||||||
|
lcdScreen->set_servo_message("MIDDLE");
|
||||||
|
}
|
||||||
this->grbl->mouveForward(CONVOYER_LEN);
|
this->grbl->mouveForward(CONVOYER_LEN);
|
||||||
} else {
|
} else {
|
||||||
//si rien
|
|
||||||
//je check si le stepper est en iddle
|
|
||||||
if(this->grbl->isIddle()){
|
if(this->grbl->isIddle()){
|
||||||
//si oui j'avance de 5 mm
|
|
||||||
this->grbl->mouveForward(5);
|
this->grbl->mouveForward(5);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//j'update la position du servo
|
|
||||||
//this->servo->refresh();
|
|
||||||
//idée affichage:
|
|
||||||
// waitting packet
|
|
||||||
// new packet detected : ID
|
|
||||||
// check to dolibarr
|
|
||||||
// DOLIBARR ID found stockage in progress
|
|
||||||
// stoage done
|
|
||||||
// ERR DOLIBARR ID not found
|
|
||||||
|
|
||||||
//idée algo v1.5 (ajou petite gestion d'erreur)
|
|
||||||
//je lis la valeur NFC
|
|
||||||
//si qqc
|
|
||||||
//je demande a dolibard ou j'envoie
|
|
||||||
//j'envoie au servo la commande
|
|
||||||
//j'avance le moteur jusqu'a X (a definir)
|
|
||||||
//si rien j'avance le moteur (5mm)
|
|
||||||
//si le lecteur de sortie voi pas de colis
|
|
||||||
//on affiche une erreur de colis non lue
|
|
||||||
//si un seul colis
|
|
||||||
//on dit que le colis est bien trié (avec porte de sortie)
|
|
||||||
//si il y a 2 colis (ou plus)
|
|
||||||
//on affiche une erreur de bourrage
|
|
||||||
|
|
||||||
//idée algo v2
|
|
||||||
//utiliser une pile
|
|
||||||
//utiliser le 2nd lecteur pour vidé la pile
|
|
||||||
//gestion d'erreur complete avec celle du dessus plus celle de la pile
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user