From 47f9efbbe45c958108862d2ec63fb30a2fc73a4c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kiripolszky=20K=C3=A1roly?= Date: Thu, 25 May 2023 19:02:19 +0200 Subject: [PATCH] Hide VTX menu when feature is unavailable --- src/SCRIPTS/BF/features.lua | 5 +++++ src/SCRIPTS/BF/ui.lua | 20 +++++++++++++++++++- src/SCRIPTS/BF/ui_init.lua | 13 +++++++++---- src/SCRIPTS/BF/vtx_tables.lua | 2 ++ src/SCRIPTS/TOOLS/bf.lua | 1 + 5 files changed, 36 insertions(+), 5 deletions(-) create mode 100644 src/SCRIPTS/BF/features.lua diff --git a/src/SCRIPTS/BF/features.lua b/src/SCRIPTS/BF/features.lua new file mode 100644 index 00000000..d56d8ff2 --- /dev/null +++ b/src/SCRIPTS/BF/features.lua @@ -0,0 +1,5 @@ +local features = { + vtx = true, +} + +return features diff --git a/src/SCRIPTS/BF/ui.lua b/src/SCRIPTS/BF/ui.lua index fee070ea..1dd11612 100644 --- a/src/SCRIPTS/BF/ui.lua +++ b/src/SCRIPTS/BF/ui.lua @@ -82,6 +82,24 @@ local function confirm(page) collectgarbage() end +local function filterAvailablePages(pageFiles) + local newPageFiles = pageFiles + + local function skipPage(script) + local currentPageFiles = {} + for i = 1, #newPageFiles do + if newPageFiles[i].script ~= script then + currentPageFiles[#currentPageFiles + 1] = newPageFiles[i] + end + end + newPageFiles = currentPageFiles + end + + if not features.vtx then skipPage("vtx.lua") end + + return newPageFiles +end + local function createPopupMenu() popupMenuActive = 1 popupMenu = {} @@ -296,7 +314,7 @@ local function run_ui(event) return 0 end init = nil - PageFiles = assert(loadScript("pages.lua"))() + PageFiles = filterAvailablePages(assert(loadScript("pages.lua"))()) invalidatePages() uiState = prevUiState or uiStatus.mainMenu prevUiState = nil diff --git a/src/SCRIPTS/BF/ui_init.lua b/src/SCRIPTS/BF/ui_init.lua index 29ca80ec..1c624c8f 100644 --- a/src/SCRIPTS/BF/ui_init.lua +++ b/src/SCRIPTS/BF/ui_init.lua @@ -22,10 +22,15 @@ local function init() mcuIdReceived = getMCUId.f() if mcuIdReceived then getMCUId = nil - local f = loadScript("VTX_TABLES/"..mcuId..".lua") - if f and f() then - vtxTablesReceived = true - f = nil + local f = loadScript("VTX_TABLES/" .. mcuId .. ".lua") + if f then + local table = f() + if table then + vtxTablesReceived = true + features.vtx = 0 < table.frequenciesPerBand + f = nil + table = nil + end end collectgarbage() f = loadScript("BOARD_INFO/"..mcuId..".lua") diff --git a/src/SCRIPTS/BF/vtx_tables.lua b/src/SCRIPTS/BF/vtx_tables.lua index d7edbba6..13f05265 100644 --- a/src/SCRIPTS/BF/vtx_tables.lua +++ b/src/SCRIPTS/BF/vtx_tables.lua @@ -29,10 +29,12 @@ local function processMspReply(cmd, payload, err) vtxTableAvailable = true vtxFrequencyTableReceived = true vtxPowerTableReceived = true + features.vtx = false return end vtxConfigReceived = true vtxTableAvailable = payload[12] ~= 0 + features.vtx = vtxTableAvailable vtxTableConfig.bands = payload[13] vtxTableConfig.channels = payload[14] vtxTableConfig.powerLevels = payload[15] diff --git a/src/SCRIPTS/TOOLS/bf.lua b/src/SCRIPTS/TOOLS/bf.lua index 3c4ee8b1..2b42f18b 100644 --- a/src/SCRIPTS/TOOLS/bf.lua +++ b/src/SCRIPTS/TOOLS/bf.lua @@ -12,6 +12,7 @@ if scriptsCompiled then radio = assert(loadScript("radios.lua"))().msp assert(loadScript(protocol.mspTransport))() assert(loadScript("MSP/common.lua"))() + features = assert(loadScript("features.lua"))() run = assert(loadScript("ui.lua"))() else run = assert(loadScript("COMPILE/compile.lua"))()