mirror of
https://github.com/luc-github/ESP3D.git
synced 2026-03-10 18:06:48 +01:00
### Maintenance page
* Add add tab color for mobile view
* Add spellcheck off / autocorect off in input
* Add disconnect button when authenticate enabled
* Add Invalid user or password message when authentication failed
### Board support
* Add ESP32 S2 support
* Add ESP32 S3 support
* Add ESP32 C3 support
### ESP commands
* Add command 701 to control GCODE streaming
* Remove command 901 as duplicate
* Update command 420 to add more details
* Use text as default output
* All json on all commands for formated output
### Core
* Add benchmak function to check transfer speed (for test only-not production)
* Merge code for ESP3DLib support
* Add better printer display support (M117 / Serial TFT)
* Use ESP32 analogWrite instead of emulated one
### Modules
* Display
* Refactor code
* Remove SPI ILI 9341 / 9488 support as not suitable
* Add ST7789 support (135x240 / 240x240)
* Filesystem
* Bug fixes due to esp core updates
* Better SD sharing mecanism
* Better global FS management
* FTP
* Add SD sharing support
* Better global FS management
* GCODE Host
* Add basic support for macro files
* Add ESP command support
* Use not blocking method to stream commands / handle response
* Notifications
* Add IFTTT notification service
* Add WebUI notification
* Add ESP3D display notification
* WebDav
* Add SD sharing support
* Add bug fix from https://github.com/d-a-v/ESPWebDAV
* Better global FS management
* Websocket
* Add function to handle zombies connections
* WiFi
* Fix connection to AP sometime fail
* Fix low signal not diplayed in ESP420 even connected
* Add AP Setup mode
### Libraries
* Update SDFat-2.0.6 to 2.1.2
* Update ESP32SSDP 1.1.1 to 1.2.0
* Update TFT_eSPI-1.4.11 to 2.4.61
* Update arduinoWebSockets-2.3.5 to 2.3.6
* Update esp8266-oled-ssd1306-4.0.0 to 4.3.0
* Remove lvgl support
### Tools
* Add I2C scanner script
* Add python script to simulate/stress printer serial communication
### PlatformIO
* Use latest 4.4.0 Espressif32 release (ESP32-arduino core 2.0.3)
* Add fix for Flash more than 4MB
* Add Esp32 S2/S3/C3 env
* Add ESP32-ST7789 / esp32-TTGO_T_Display env
128 lines
2.6 KiB
Python
128 lines
2.6 KiB
Python
#!/usr/bin/env python3
|
|
import os
|
|
|
|
|
|
def process_index_rst(path):
|
|
# print(path)
|
|
with open(path) as fp:
|
|
last_line=""
|
|
line=""
|
|
title_tmp=""
|
|
line = fp.readline()
|
|
d = {}
|
|
while line:
|
|
if line[0:3] == '"""':
|
|
title_tmp = last_line
|
|
elif line[0:15] ==".. lv_example::":
|
|
name = line[16:].strip()
|
|
title_tmp = title_tmp.strip()
|
|
d[name] = title_tmp
|
|
last_line = line
|
|
line = fp.readline()
|
|
|
|
return(d)
|
|
|
|
h1= {
|
|
"get_started":"Get started",
|
|
"styles":"Styles",
|
|
"anim":"Animations",
|
|
"event":"Events",
|
|
"layouts":"Layouts",
|
|
"scroll":"Scrolling",
|
|
"widgets":"Widgets"
|
|
}
|
|
|
|
widgets = {
|
|
"obj":"Base object",
|
|
"arc":"Arc",
|
|
"bar":"Bar",
|
|
"btn":"Button",
|
|
"btnmatrix":"Button matrix",
|
|
"calendar":"Calendar",
|
|
"canvas":"Canvas",
|
|
"chart":"Chart",
|
|
"checkbox":"Checkbox",
|
|
"colorwheel":"Colorwheel",
|
|
"dropdown":"Dropdown",
|
|
"img":"Image",
|
|
"imgbtn":"Image button",
|
|
"keyboard":"Keyboard",
|
|
"label":"Label",
|
|
"led":"LED",
|
|
"line":"Line",
|
|
"list":"List",
|
|
"menu":"Menu",
|
|
"meter":"Meter",
|
|
"msgbox":"Message box",
|
|
"roller":"Roller",
|
|
"slider":"Slider",
|
|
"span":"Span",
|
|
"spinbox":"Spinbox",
|
|
"spinner":"Spinner",
|
|
"switch":"Switch",
|
|
"table":"Table",
|
|
"tabview":"Tabview",
|
|
"textarea":"Textarea",
|
|
"tileview":"Tabview",
|
|
"win":"Window",
|
|
}
|
|
|
|
layouts = {
|
|
"flex":"Flex",
|
|
"grid":"Grid",
|
|
}
|
|
|
|
|
|
def print_item(path, lvl, d, fout):
|
|
for k in d:
|
|
v = d[k]
|
|
if k.startswith(path + "/lv_example_"):
|
|
fout.write("#"*lvl + " " + v + "\n")
|
|
fout.write('```eval_rst\n')
|
|
fout.write(f".. lv_example:: {k}\n")
|
|
fout.write('```\n')
|
|
fout.write("\n")
|
|
|
|
def exec():
|
|
paths = [ "../examples/", "../demos/"]
|
|
fout = open("examples.md", "w")
|
|
filelist = []
|
|
|
|
for path in paths:
|
|
for root, dirs, files in os.walk(path):
|
|
for f in files:
|
|
#append the file name to the list
|
|
filelist.append(os.path.join(root,f))
|
|
|
|
filelist = [ fi for fi in filelist if fi.endswith("index.rst") ]
|
|
|
|
d_all = {}
|
|
#print all the file names
|
|
for fn in filelist:
|
|
d_act = process_index_rst(fn)
|
|
d_all.update(d_act)
|
|
|
|
fout.write("```eval_rst\n")
|
|
fout.write(".. include:: /header.rst\n")
|
|
fout.write(":github_url: |github_link_base|/examples.md\n")
|
|
fout.write("```\n")
|
|
fout.write("\n")
|
|
fout.write("# Examples\n")
|
|
|
|
for h in h1:
|
|
fout.write("## " + h1[h] + "\n")
|
|
|
|
if h == "widgets":
|
|
for w in widgets:
|
|
fout.write("### " + widgets[w] + "\n")
|
|
print_item(h + "/" + w, 4, d_all, fout)
|
|
elif h == "layouts":
|
|
for l in layouts:
|
|
fout.write("### " + layouts[l] + "\n")
|
|
print_item(h + "/" + l, 4, d_all, fout)
|
|
else:
|
|
print_item(h, 3, d_all, fout)
|
|
|
|
fout.write("")
|
|
|