#405 helper functions, enums, and name tables added to themes.lua

This commit is contained in:
Mikayla Fischler 2024-03-09 12:41:45 -05:00
parent 6c89b3134c
commit 5d760a0524
2 changed files with 113 additions and 46 deletions

View File

@ -8,6 +8,7 @@ local network = require("scada-common.network")
local ppm = require("scada-common.ppm") local ppm = require("scada-common.ppm")
local tcd = require("scada-common.tcd") local tcd = require("scada-common.tcd")
local util = require("scada-common.util") local util = require("scada-common.util")
local themes = require("graphics.themes")
local core = require("graphics.core") local core = require("graphics.core")
@ -174,9 +175,9 @@ local fields = {
{ "LogMode", "Log Mode", log.MODE.APPEND }, { "LogMode", "Log Mode", log.MODE.APPEND },
{ "LogPath", "Log Path", "/log.txt" }, { "LogPath", "Log Path", "/log.txt" },
{ "LogDebug","Log Debug Messages", false }, { "LogDebug","Log Debug Messages", false },
{ "MainTheme", "Main UI Theme", 1 }, { "MainTheme", "Main UI Theme", themes.UI_THEME.SMOOTH_STONE },
{ "FrontPanelTheme", "Front Panel Theme", 1 }, { "FrontPanelTheme", "Front Panel Theme", themes.FP_THEME.SANDSTONE },
{ "ColorMode", "Color Mode", 1 } { "ColorMode", "Color Mode", themes.COLOR_MODE.STANDARD }
} }
-- check if a value is an integer within a range (inclusive) -- check if a value is an integer within a range (inclusive)
@ -832,10 +833,10 @@ local function config_view(display)
TextBox{parent=clr_c_1,x=1,y=4,height=2,text="Click 'Accessibility' below to access color blind assistive options.",fg_bg=g_lg_fg_bg} TextBox{parent=clr_c_1,x=1,y=4,height=2,text="Click 'Accessibility' below to access color blind assistive options.",fg_bg=g_lg_fg_bg}
TextBox{parent=clr_c_1,x=1,y=7,height=1,text="Main UI Theme"} TextBox{parent=clr_c_1,x=1,y=7,height=1,text="Main UI Theme"}
local main_theme = RadioButton{parent=clr_c_1,x=1,y=8,default=ini_cfg.MainTheme,options={"Smooth Stone","Deepslate"},callback=function()end,radio_colors=cpair(colors.lightGray,colors.black),select_color=colors.magenta} local main_theme = RadioButton{parent=clr_c_1,x=1,y=8,default=ini_cfg.MainTheme,options=themes.UI_THEME_NAMES,callback=function()end,radio_colors=cpair(colors.lightGray,colors.black),select_color=colors.magenta}
TextBox{parent=clr_c_1,x=18,y=7,height=1,text="Front Panel Theme"} TextBox{parent=clr_c_1,x=18,y=7,height=1,text="Front Panel Theme"}
local fp_theme = RadioButton{parent=clr_c_1,x=18,y=8,default=ini_cfg.FrontPanelTheme,options={"Sandstone","Basalt"},callback=function()end,radio_colors=cpair(colors.lightGray,colors.black),select_color=colors.magenta} local fp_theme = RadioButton{parent=clr_c_1,x=18,y=8,default=ini_cfg.FrontPanelTheme,options=themes.FP_THEME_NAMES,callback=function()end,radio_colors=cpair(colors.lightGray,colors.black),select_color=colors.magenta}
TextBox{parent=clr_c_2,x=1,y=1,height=6,text="By default, this project uses green/red heavily to distinguish ok and not, with some indicators also using multiple colors. By selecting a color blindness below, blues will be used instead of greens on indicators and multi-color indicators will be split up as space permits."} TextBox{parent=clr_c_2,x=1,y=1,height=6,text="By default, this project uses green/red heavily to distinguish ok and not, with some indicators also using multiple colors. By selecting a color blindness below, blues will be used instead of greens on indicators and multi-color indicators will be split up as space permits."}
@ -857,7 +858,7 @@ local function config_view(display)
end end
end end
local c_mode = RadioButton{parent=clr_c_2,x=1,y=8,default=ini_cfg.ColorMode,options={"None","Protanopia","Deuteranopia","Tritanopia"},callback=recolor,radio_colors=cpair(colors.lightGray,colors.black),select_color=colors.magenta} local c_mode = RadioButton{parent=clr_c_2,x=1,y=8,default=ini_cfg.ColorMode,options=themes.COLOR_MODE_NAMES,callback=recolor,radio_colors=cpair(colors.lightGray,colors.black),select_color=colors.magenta}
local _ = IndLight{parent=clr_c_2,x=20,y=8,label="Good",colors=cpair(colors.black,colors.green),value=true} local _ = IndLight{parent=clr_c_2,x=20,y=8,label="Good",colors=cpair(colors.black,colors.green),value=true}
_ = IndLight{parent=clr_c_2,x=20,y=9,label="Warning",colors=cpair(colors.black,colors.yellow),value=true} _ = IndLight{parent=clr_c_2,x=20,y=9,label="Warning",colors=cpair(colors.black,colors.yellow),value=true}
@ -1332,11 +1333,11 @@ local function config_view(display)
elseif f[1] == "TempScale" then elseif f[1] == "TempScale" then
if raw == 1 then val = "Kelvin" elseif raw == 2 then val = "Celsius" elseif raw == 3 then val = "Fahrenheit" elseif raw == 4 then val = "Rankine" end if raw == 1 then val = "Kelvin" elseif raw == 2 then val = "Celsius" elseif raw == 3 then val = "Fahrenheit" elseif raw == 4 then val = "Rankine" end
elseif f[1] == "MainTheme" then elseif f[1] == "MainTheme" then
if raw == 1 then val = "Smooth Stone" elseif raw == 2 then val = "Deepslate" end val = util.strval(themes.ui_theme_name(raw))
elseif f[1] == "FrontPanelTheme" then elseif f[1] == "FrontPanelTheme" then
if raw == 1 then val = "Sandstone" elseif raw == 2 then val = "Basalt" end val = util.strval(themes.fp_theme_name(raw))
elseif f[1] == "ColorMode" then elseif f[1] == "ColorMode" then
if raw == 1 then val = "Standard" elseif raw == 2 then val = "Protanopia" elseif raw == 3 then val = "Deuteranopia" elseif raw == 4 then val = "Tritanopia" end val = util.strval(themes.color_mode_name(raw))
elseif f[1] == "UnitDisplays" and type(cfg.UnitDisplays) == "table" then elseif f[1] == "UnitDisplays" and type(cfg.UnitDisplays) == "table" then
val = "" val = ""
for idx = 1, #cfg.UnitDisplays do for idx = 1, #cfg.UnitDisplays do

View File

@ -9,12 +9,76 @@ local cpair = core.cpair
---@class graphics_themes ---@class graphics_themes
local themes = {} local themes = {}
-- add color mappings for front panel -- add color mappings for front panels
colors.ivory = colors.pink colors.ivory = colors.pink
colors.yellow_hc = colors.purple colors.yellow_hc = colors.purple
colors.red_off = colors.brown colors.red_off = colors.brown
colors.yellow_off = colors.magenta colors.yellow_off = colors.magenta
colors.green_off = colors.lime colors.green_off = colors.lime
--#region Types
---@enum UI_THEME
themes.UI_THEME = { SMOOTH_STONE = 1, DEEPSLATE = 2 }
themes.UI_THEME_NAMES = { "Smooth Stone", "Deepslate" }
-- attempts to get the string name of a main ui theme
---@nodiscard
---@param id any
---@return string|nil
function themes.ui_theme_name(id)
if id == themes.UI_THEME.SMOOTH_STONE or
id == themes.UI_THEME.DEEPSLATE then
return themes.UI_THEME_NAMES[id]
else return nil end
end
---@enum FP_THEME
themes.FP_THEME = { SANDSTONE = 1, BASALT = 2 }
themes.FP_THEME_NAMES = { "Sandstone", "Basalt" }
-- attempts to get the string name of a front panel theme
---@nodiscard
---@param id any
---@return string|nil
function themes.fp_theme_name(id)
if id == themes.FP_THEME.SANDSTONE or
id == themes.FP_THEME.BASALT then
return themes.FP_THEME_NAMES[id]
else return nil end
end
---@enum COLOR_MODE
themes.COLOR_MODE = {
STANDARD = 1,
DEUTERANOPIA = 2,
PROTANOPIA = 3,
TRITANOPIA = 4
}
themes.COLOR_MODE_NAMES = {
"Standard",
"Deuteranopia",
"Protanopia",
"Tritanopia"
}
-- attempts to get the string name of a color mode
---@nodiscard
---@param id any
---@return string|nil
function themes.color_mode_name(id)
if id == themes.COLOR_MODE.STANDARD or
id == themes.COLOR_MODE.DEUTERANOPIA or
id == themes.COLOR_MODE.PROTANOPIA or
id == themes.COLOR_MODE.TRITANOPIA then
return themes.COLOR_MODE_NAMES[id]
else return nil end
end
--#endregion
--#region Front Panel Themes
---@class fp_theme ---@class fp_theme
themes.sandstone = { themes.sandstone = {
@ -31,22 +95,22 @@ themes.sandstone = {
field_box = cpair(colors.gray, colors.white), field_box = cpair(colors.gray, colors.white),
colors = { colors = {
{ c = colors.red, hex = 0xdf4949 }, -- RED ON { c = colors.red, hex = 0xdf4949 },
{ c = colors.orange, hex = 0xffb659 }, { c = colors.orange, hex = 0xffb659 },
{ c = colors.yellow, hex = 0xf9fb53 }, -- YELLOW ON { c = colors.yellow, hex = 0xf9fb53 },
{ c = colors.lime, hex = 0x16665a }, -- GREEN OFF { c = colors.green_off, hex = 0x16665a },
{ c = colors.green, hex = 0x6be551 }, -- GREEN ON { c = colors.green, hex = 0x6be551 },
{ c = colors.cyan, hex = 0x34bac8 }, { c = colors.cyan, hex = 0x34bac8 },
{ c = colors.lightBlue, hex = 0x6cc0f2 }, { c = colors.lightBlue, hex = 0x6cc0f2 },
{ c = colors.blue, hex = 0x0096ff }, { c = colors.blue, hex = 0x0096ff },
{ c = colors.purple, hex = 0xe3bc2a }, -- YELLOW HIGH CONTRAST { c = colors.yellow_hc, hex = 0xe3bc2a },
{ c = colors.pink, hex = 0xdcd9ca }, -- IVORY { c = colors.ivory, hex = 0xdcd9ca },
{ c = colors.magenta, hex = 0x85862c }, -- YELLOW OFF { c = colors.yellow_off, hex = 0x85862c },
{ c = colors.white, hex = 0xf0f0f0 }, { c = colors.white, hex = 0xf0f0f0 },
{ c = colors.lightGray, hex = 0xb1b8b3 }, { c = colors.lightGray, hex = 0xb1b8b3 },
{ c = colors.gray, hex = 0x575757 }, { c = colors.gray, hex = 0x575757 },
{ c = colors.black, hex = 0x191919 }, { c = colors.black, hex = 0x191919 },
{ c = colors.brown, hex = 0x672223 } -- RED OFF { c = colors.red_off, hex = 0x672223 }
} }
} }
@ -65,22 +129,22 @@ themes.basalt = {
field_box = cpair(colors.white, colors.gray), field_box = cpair(colors.white, colors.gray),
colors = { colors = {
{ c = colors.red, hex = 0xf18486 }, -- RED ON { c = colors.red, hex = 0xf18486 },
{ c = colors.orange, hex = 0xffb659 }, { c = colors.orange, hex = 0xffb659 },
{ c = colors.yellow, hex = 0xefe37c }, -- YELLOW ON { c = colors.yellow, hex = 0xefe37c },
{ c = colors.lime, hex = 0x436b41 }, -- GREEN OFF { c = colors.green_off, hex = 0x436b41 },
{ c = colors.green, hex = 0x7ae175 }, -- GREEN ON { c = colors.green, hex = 0x7ae175 },
{ c = colors.cyan, hex = 0x5ec7d1 }, { c = colors.cyan, hex = 0x5ec7d1 },
{ c = colors.lightBlue, hex = 0x7dc6f2 }, { c = colors.lightBlue, hex = 0x7dc6f2 },
{ c = colors.blue, hex = 0x56aae6 }, { c = colors.blue, hex = 0x56aae6 },
{ c = colors.purple, hex = 0xe9cd68 }, -- YELLOW HIGH CONTRAST { c = colors.yellow_hc, hex = 0xe9cd68 },
{ c = colors.pink, hex = 0x4d4e52 }, -- IVORY { c = colors.ivory, hex = 0x4d4e52 },
{ c = colors.magenta, hex = 0x757040 }, -- YELLOW OFF { c = colors.yellow_off, hex = 0x757040 },
{ c = colors.white, hex = 0xbfbfbf }, { c = colors.white, hex = 0xbfbfbf },
{ c = colors.lightGray, hex = 0x848794 }, { c = colors.lightGray, hex = 0x848794 },
{ c = colors.gray, hex = 0x5c5f68 }, { c = colors.gray, hex = 0x5c5f68 },
{ c = colors.black, hex = 0x262626 }, { c = colors.black, hex = 0x262626 },
{ c = colors.brown, hex = 0x653839 } -- RED OFF { c = colors.red_off, hex = 0x653839 }
} }
} }
@ -103,4 +167,6 @@ function themes.get_fp_style(theme)
return style return style
end end
--#endregion
return themes return themes