2022-04-24 17:46:01 +01:00
|
|
|
# OpenHASP demo
|
2024-03-10 22:03:40 +00:00
|
|
|
# rm haspmota_demo.tapp ; zip -j -0 haspmota_demo.tapp ../haspmota_src/haspmota_demo/*
|
2022-04-24 17:46:01 +01:00
|
|
|
|
|
|
|
if !tasmota.memory().contains("psram")
|
|
|
|
print("HSP: Error: OpenHASP demo requires PSRAM")
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
import lv_tasmota_log
|
|
|
|
import lv_tasmota_info
|
|
|
|
import lv_wifi_graph
|
|
|
|
|
2022-05-20 20:29:39 +01:00
|
|
|
import haspmota
|
2022-10-07 16:50:25 +01:00
|
|
|
haspmota.start(false, tasmota.wd + "pages.jsonl")
|
2022-04-24 17:46:01 +01:00
|
|
|
|
|
|
|
var prev_day = -1
|
|
|
|
def set_watch()
|
|
|
|
import global
|
|
|
|
var now = tasmota.rtc()
|
|
|
|
var time_raw = now['local']
|
|
|
|
var time = tasmota.time_dump(time_raw)
|
|
|
|
# set second
|
|
|
|
global.p5b13.angle = 60 * time['sec']
|
|
|
|
# set minutes
|
|
|
|
global.p5b12.angle = 60 * time['min']
|
|
|
|
# set hours
|
|
|
|
global.p5b11.angle = 300 * (time['hour'] % 12) + time['min'] * 5
|
|
|
|
# set day
|
|
|
|
if time['day'] != prev_day
|
|
|
|
global.p5b15.text = str(time['day'])
|
|
|
|
prev_day = time['day']
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def run_watch()
|
|
|
|
set_watch()
|
|
|
|
tasmota.set_timer(100, run_watch)
|
|
|
|
end
|
|
|
|
run_watch()
|
|
|
|
|
|
|
|
def p5_in()
|
2022-04-25 11:03:18 +01:00
|
|
|
import global
|
2022-04-24 17:46:01 +01:00
|
|
|
global.p0b101.bg_opa = 0
|
|
|
|
global.p0b102.bg_opa = 0
|
|
|
|
global.p0b103.bg_opa = 0
|
|
|
|
global.p0b11.bg_opa = 0
|
|
|
|
end
|
|
|
|
|
|
|
|
def p5_out()
|
2022-04-25 11:03:18 +01:00
|
|
|
import global
|
2022-04-24 17:46:01 +01:00
|
|
|
global.p0b101.bg_opa = 255
|
|
|
|
global.p0b102.bg_opa = 255
|
|
|
|
global.p0b103.bg_opa = 255
|
|
|
|
global.p0b11.bg_opa = 255
|
|
|
|
end
|
|
|
|
|
2023-05-03 16:33:21 +01:00
|
|
|
tasmota.add_rule("hasp#p5=in", p5_in)
|
|
|
|
tasmota.add_rule("hasp#p5=out", p5_out)
|