mirror of
https://github.com/MikaylaFischler/cc-mek-scada.git
synced 2024-08-30 18:22:34 +00:00
#101 initial coordinator control interface completed
This commit is contained in:
parent
b5c70b0d37
commit
3e74d6c998
@ -19,7 +19,7 @@ local iocontrol = require("coordinator.iocontrol")
|
|||||||
local renderer = require("coordinator.renderer")
|
local renderer = require("coordinator.renderer")
|
||||||
local sounder = require("coordinator.sounder")
|
local sounder = require("coordinator.sounder")
|
||||||
|
|
||||||
local COORDINATOR_VERSION = "beta-v0.8.17"
|
local COORDINATOR_VERSION = "beta-v0.8.18"
|
||||||
|
|
||||||
local print = util.print
|
local print = util.print
|
||||||
local println = util.println
|
local println = util.println
|
||||||
|
@ -44,7 +44,7 @@ local function new_view(root, x, y)
|
|||||||
local hzd_fg_bg = cpair(colors.white, colors.gray)
|
local hzd_fg_bg = cpair(colors.white, colors.gray)
|
||||||
local dis_colors = cpair(colors.white, colors.lightGray)
|
local dis_colors = cpair(colors.white, colors.lightGray)
|
||||||
|
|
||||||
local main = Div{parent=root,width=80,height=24,x=x,y=y}
|
local main = Div{parent=root,width=104,height=24,x=x,y=y}
|
||||||
|
|
||||||
local scram = HazardButton{parent=main,x=1,y=1,text="FAC SCRAM",accent=colors.yellow,dis_colors=dis_colors,callback=process.fac_scram,fg_bg=hzd_fg_bg}
|
local scram = HazardButton{parent=main,x=1,y=1,text="FAC SCRAM",accent=colors.yellow,dis_colors=dis_colors,callback=process.fac_scram,fg_bg=hzd_fg_bg}
|
||||||
|
|
||||||
@ -81,7 +81,7 @@ local function new_view(root, x, y)
|
|||||||
-- process control --
|
-- process control --
|
||||||
---------------------
|
---------------------
|
||||||
|
|
||||||
local proc = Div{parent=main,width=54,height=24,x=27,y=1}
|
local proc = Div{parent=main,width=78,height=24,x=27,y=1}
|
||||||
|
|
||||||
-----------------------------
|
-----------------------------
|
||||||
-- process control targets --
|
-- process control targets --
|
||||||
@ -126,7 +126,7 @@ local function new_view(root, x, y)
|
|||||||
-- unit limits --
|
-- unit limits --
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
local limit_div = Div{parent=proc,width=40,height=19,x=34,y=6}
|
local limit_div = Div{parent=proc,width=21,height=19,x=34,y=6}
|
||||||
|
|
||||||
local rate_limits = {}
|
local rate_limits = {}
|
||||||
|
|
||||||
@ -140,7 +140,7 @@ local function new_view(root, x, y)
|
|||||||
|
|
||||||
local lim_ctl = Div{parent=limit_div,x=9,y=_y,width=14,height=3,fg_bg=cpair(colors.gray,colors.white)}
|
local lim_ctl = Div{parent=limit_div,x=9,y=_y,width=14,height=3,fg_bg=cpair(colors.gray,colors.white)}
|
||||||
rate_limits[i] = SpinboxNumeric{parent=lim_ctl,x=2,y=1,whole_num_precision=4,fractional_precision=1,min=0.1,arrow_fg_bg=cpair(colors.gray,colors.white),fg_bg=bw_fg_bg}
|
rate_limits[i] = SpinboxNumeric{parent=lim_ctl,x=2,y=1,whole_num_precision=4,fractional_precision=1,min=0.1,arrow_fg_bg=cpair(colors.gray,colors.white),fg_bg=bw_fg_bg}
|
||||||
TextBox{parent=lim_ctl,x=9,y=2,text="mB/t"}
|
TextBox{parent=lim_ctl,x=9,y=2,text="mB/t",width=4,height=1}
|
||||||
|
|
||||||
unit.unit_ps.subscribe("max_burn", rate_limits[i].set_max)
|
unit.unit_ps.subscribe("max_burn", rate_limits[i].set_max)
|
||||||
unit.unit_ps.subscribe("burn_limit", rate_limits[i].set_value)
|
unit.unit_ps.subscribe("burn_limit", rate_limits[i].set_value)
|
||||||
@ -150,6 +150,28 @@ local function new_view(root, x, y)
|
|||||||
unit.unit_ps.subscribe("act_burn_rate", cur_burn.update)
|
unit.unit_ps.subscribe("act_burn_rate", cur_burn.update)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-------------------
|
||||||
|
-- unit statuses --
|
||||||
|
-------------------
|
||||||
|
|
||||||
|
local stat_div = Div{parent=proc,width=38,height=19,x=57,y=6}
|
||||||
|
|
||||||
|
for i = 1, facility.num_units do
|
||||||
|
local unit = units[i] ---@type ioctl_unit
|
||||||
|
|
||||||
|
local _y = ((i - 1) * 5) + 1
|
||||||
|
|
||||||
|
local unit_tag = Div{parent=stat_div,x=1,y=_y,width=8,height=4,fg_bg=cpair(colors.black,colors.lightBlue)}
|
||||||
|
TextBox{parent=unit_tag,x=2,y=2,text="Unit "..i.." Status",width=7,height=2}
|
||||||
|
|
||||||
|
local lights = Div{parent=stat_div,x=9,y=_y,width=12,height=4,fg_bg=bw_fg_bg}
|
||||||
|
local ready = IndicatorLight{parent=lights,x=2,y=2,label="Ready",colors=cpair(colors.green,colors.gray)}
|
||||||
|
local degraded = IndicatorLight{parent=lights,x=2,y=3,label="Degraded",colors=cpair(colors.red,colors.gray),flash=true,period=period.BLINK_250_MS}
|
||||||
|
|
||||||
|
unit.unit_ps.subscribe("U_AutoReady", ready.update)
|
||||||
|
unit.unit_ps.subscribe("U_AutoDegraded", degraded.update)
|
||||||
|
end
|
||||||
|
|
||||||
-------------------------
|
-------------------------
|
||||||
-- controls and status --
|
-- controls and status --
|
||||||
-------------------------
|
-------------------------
|
||||||
|
@ -88,7 +88,7 @@ local function init(monitor)
|
|||||||
-- testing
|
-- testing
|
||||||
---@fixme remove test code
|
---@fixme remove test code
|
||||||
|
|
||||||
ColorMap{parent=main,x=98,y=(main.height()-1)}
|
-- ColorMap{parent=main,x=98,y=(main.height()-1)}
|
||||||
|
|
||||||
local audio = Div{parent=main,width=23,height=23,x=107,y=cnc_y_start}
|
local audio = Div{parent=main,width=23,height=23,x=107,y=cnc_y_start}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user