2023-02-14 03:11:31 +00:00
|
|
|
-- Radiation Indicator Graphics Element
|
|
|
|
|
2023-02-16 00:52:28 +00:00
|
|
|
local types = require("scada-common.types")
|
2023-02-14 03:11:31 +00:00
|
|
|
local util = require("scada-common.util")
|
|
|
|
|
|
|
|
local element = require("graphics.element")
|
|
|
|
|
|
|
|
---@class rad_indicator_args
|
|
|
|
---@field label string indicator label
|
|
|
|
---@field format string data format (lua string format)
|
|
|
|
---@field commas? boolean whether to use commas if a number is given (default to false)
|
|
|
|
---@field lu_colors? cpair label foreground color (a), unit foreground color (b)
|
|
|
|
---@field value any default value
|
|
|
|
---@field parent graphics_element
|
|
|
|
---@field id? string element id
|
|
|
|
---@field x? integer 1 if omitted
|
2023-07-10 03:42:44 +00:00
|
|
|
---@field y? integer auto incremented if omitted
|
2023-02-14 03:11:31 +00:00
|
|
|
---@field width integer length
|
|
|
|
---@field fg_bg? cpair foreground/background colors
|
2023-05-25 21:40:16 +00:00
|
|
|
---@field hidden? boolean true to hide on initial draw
|
2023-02-14 03:11:31 +00:00
|
|
|
|
|
|
|
-- new radiation indicator
|
2023-02-25 00:50:01 +00:00
|
|
|
---@nodiscard
|
2023-02-14 03:11:31 +00:00
|
|
|
---@param args rad_indicator_args
|
|
|
|
---@return graphics_element element, element_id id
|
|
|
|
local function rad(args)
|
|
|
|
assert(type(args.label) == "string", "graphics.elements.indicators.rad: label is a required field")
|
|
|
|
assert(type(args.format) == "string", "graphics.elements.indicators.rad: format is a required field")
|
|
|
|
assert(util.is_int(args.width), "graphics.elements.indicators.rad: width is a required field")
|
|
|
|
|
|
|
|
-- single line
|
|
|
|
args.height = 1
|
|
|
|
|
|
|
|
-- create new graphics element base object
|
|
|
|
local e = element.new(args)
|
|
|
|
|
|
|
|
-- label color
|
|
|
|
if args.lu_colors ~= nil then
|
2023-08-31 01:11:57 +00:00
|
|
|
e.w_set_fgd(args.lu_colors.color_a)
|
2023-02-14 03:11:31 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
-- write label
|
2023-08-31 01:11:57 +00:00
|
|
|
e.w_set_cur(1, 1)
|
|
|
|
e.w_write(args.label)
|
2023-02-14 03:11:31 +00:00
|
|
|
|
|
|
|
local label_len = string.len(args.label)
|
|
|
|
local data_start = 1
|
|
|
|
local clear_width = args.width
|
|
|
|
|
|
|
|
if label_len > 0 then
|
|
|
|
data_start = data_start + (label_len + 1)
|
|
|
|
clear_width = args.width - (label_len + 1)
|
|
|
|
end
|
|
|
|
|
|
|
|
-- on state change
|
|
|
|
---@param value any new value
|
|
|
|
function e.on_update(value)
|
|
|
|
e.value = value.radiation
|
|
|
|
|
|
|
|
-- clear old data and label
|
2023-08-31 01:11:57 +00:00
|
|
|
e.w_set_cur(data_start, 1)
|
|
|
|
e.w_write(util.spaces(clear_width))
|
2023-02-14 03:11:31 +00:00
|
|
|
|
|
|
|
-- write data
|
|
|
|
local data_str = util.sprintf(args.format, e.value)
|
2023-08-31 01:11:57 +00:00
|
|
|
e.w_set_cur(data_start, 1)
|
|
|
|
e.w_set_fgd(e.fg_bg.fgd)
|
2023-02-14 03:11:31 +00:00
|
|
|
if args.commas then
|
2023-08-31 01:11:57 +00:00
|
|
|
e.w_write(util.comma_format(data_str))
|
2023-02-14 03:11:31 +00:00
|
|
|
else
|
2023-08-31 01:11:57 +00:00
|
|
|
e.w_write(data_str)
|
2023-02-14 03:11:31 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
-- write unit
|
|
|
|
if args.lu_colors ~= nil then
|
2023-08-31 01:11:57 +00:00
|
|
|
e.w_set_fgd(args.lu_colors.color_b)
|
2023-02-14 03:11:31 +00:00
|
|
|
end
|
2023-08-31 01:11:57 +00:00
|
|
|
e.w_write(" " .. value.unit)
|
2023-02-14 03:11:31 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
-- set the value
|
|
|
|
---@param val any new value
|
|
|
|
function e.set_value(val) e.on_update(val) end
|
|
|
|
|
|
|
|
-- initial value draw
|
2023-02-16 00:52:28 +00:00
|
|
|
e.on_update(types.new_zero_radiation_reading())
|
2023-02-14 03:11:31 +00:00
|
|
|
|
2023-05-30 23:51:10 +00:00
|
|
|
return e.complete()
|
2023-02-14 03:11:31 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
return rad
|