local font = require("font") local vol = require("volume") local theme = require("theme") -- Set up property bindings that are used across every screen. GLOBAL_BINDINGS = { vol.current_pct:bind(function(pct) require("alerts").show(function() local container = lvgl.Object(nil, { w = lvgl.PCT(80), h = lvgl.SIZE_CONTENT, flex = { flex_direction = "column", justify_content = "center", align_items = "center", align_content = "center", }, bg_opa = lvgl.OPA(100), bg_color = "#fafafa", radius = 8, pad_all = 2, }) container:Label { text = string.format("Volume %i%%", pct), text_font = font.fusion_10 } container:Bar { w = lvgl.PCT(100), h = 8, range = { min = 0, max = 100 }, value = pct, } container:center() end) end), } local lvgl = require("lvgl") local my_theme = { base = { {lvgl.PART.MAIN, lvgl.Style { bg_opa = lvgl.OPA(0), text_font = font.fusion_12, text_color = "#ff0000", -- Red to check it applies }}, {lvgl.STATE.FOCUSED, lvgl.Style { bg_opa = lvgl.OPA(100), bg_color = "#0000ff", -- ew text_color = "#ff0000", -- Red to check it applies }}, }, button = { {lvgl.STATE.FOCUSED, lvgl.Style { bg_color = "#00ff00", }}, {lvgl.PART.MAIN, lvgl.Style { bg_color = "#00ff00", }}, }, } theme.set(my_theme) local backstack = require("backstack") local main_menu = require("main_menu") backstack.push(main_menu)