2024-06-04 00:21:54 +00:00
|
|
|
--
|
|
|
|
-- System Guide
|
|
|
|
--
|
|
|
|
|
2024-06-13 00:01:31 +00:00
|
|
|
local util = require("scada-common.util")
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-07 02:54:26 +00:00
|
|
|
local iocontrol = require("pocket.iocontrol")
|
2024-06-14 01:43:56 +00:00
|
|
|
local pocket = require("pocket.pocket")
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-07 02:54:26 +00:00
|
|
|
local docs = require("pocket.ui.docs")
|
2024-06-14 01:43:56 +00:00
|
|
|
-- local style = require("pocket.ui.style")
|
2024-06-05 00:31:29 +00:00
|
|
|
|
2024-06-07 02:30:55 +00:00
|
|
|
local guide_section = require("pocket.ui.pages.guide_section")
|
|
|
|
|
2024-06-07 02:54:26 +00:00
|
|
|
local core = require("graphics.core")
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-07 02:54:26 +00:00
|
|
|
local Div = require("graphics.elements.div")
|
|
|
|
local ListBox = require("graphics.elements.listbox")
|
|
|
|
local MultiPane = require("graphics.elements.multipane")
|
|
|
|
local TextBox = require("graphics.elements.textbox")
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-14 01:43:56 +00:00
|
|
|
local WaitingAnim = require("graphics.elements.animations.waiting")
|
|
|
|
|
2024-06-07 02:54:26 +00:00
|
|
|
local PushButton = require("graphics.elements.controls.push_button")
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-14 01:43:56 +00:00
|
|
|
local TextField = require("graphics.elements.form.text_field")
|
|
|
|
|
2024-06-04 00:21:54 +00:00
|
|
|
local ALIGN = core.ALIGN
|
|
|
|
local cpair = core.cpair
|
|
|
|
|
2024-06-14 01:43:56 +00:00
|
|
|
local APP_ID = pocket.APP_ID
|
|
|
|
|
|
|
|
-- local label = style.label
|
|
|
|
-- local lu_col = style.label_unit_pair
|
|
|
|
-- local text_fg = style.text_fg
|
2024-06-05 00:31:29 +00:00
|
|
|
|
2024-06-04 00:21:54 +00:00
|
|
|
-- new system guide view
|
|
|
|
---@param root graphics_element parent
|
|
|
|
local function new_view(root)
|
|
|
|
local db = iocontrol.get_db()
|
|
|
|
|
2024-06-14 01:43:56 +00:00
|
|
|
local frame = Div{parent=root,x=1,y=1}
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-14 01:43:56 +00:00
|
|
|
local app = db.nav.register_app(APP_ID.GUIDE, frame)
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-14 01:43:56 +00:00
|
|
|
local load_div = Div{parent=frame,x=1,y=1}
|
|
|
|
local main = Div{parent=frame,x=1,y=1}
|
|
|
|
|
2024-06-30 17:55:13 +00:00
|
|
|
TextBox{parent=load_div,y=12,text="Loading...",alignment=ALIGN.CENTER}
|
2024-06-14 01:43:56 +00:00
|
|
|
WaitingAnim{parent=load_div,x=math.floor(main.get_width()/2)-1,y=8,fg_bg=cpair(colors.cyan,colors._INHERIT)}
|
|
|
|
|
|
|
|
local load_pane = MultiPane{parent=main,x=1,y=1,panes={load_div,main}}
|
2024-06-04 00:21:54 +00:00
|
|
|
|
|
|
|
local btn_fg_bg = cpair(colors.cyan, colors.black)
|
|
|
|
local btn_active = cpair(colors.white, colors.black)
|
2024-06-07 02:30:55 +00:00
|
|
|
local btn_disable = cpair(colors.gray, colors.black)
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-14 16:10:04 +00:00
|
|
|
app.set_sidebar({{ label = " # ", tall = true, color = core.cpair(colors.black, colors.green), callback = function () db.nav.open_app(APP_ID.ROOT) end }})
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-14 16:10:04 +00:00
|
|
|
local page_div = nil ---@type nil|graphics_element
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-14 16:10:04 +00:00
|
|
|
-- load the app (create the elements)
|
2024-06-04 00:21:54 +00:00
|
|
|
local function load()
|
2024-06-14 16:10:04 +00:00
|
|
|
local list = {
|
|
|
|
{ label = " # ", tall = true, color = core.cpair(colors.black, colors.green), callback = function () db.nav.open_app(APP_ID.ROOT) end },
|
|
|
|
{ label = " \x14 ", color = core.cpair(colors.black, colors.cyan), callback = function () app.switcher(1) end },
|
|
|
|
{ label = "__?", color = core.cpair(colors.black, colors.lightGray), callback = function () app.switcher(2) end }
|
|
|
|
}
|
|
|
|
|
|
|
|
app.set_sidebar(list)
|
|
|
|
|
|
|
|
page_div = Div{parent=main,y=2}
|
2024-06-04 00:21:54 +00:00
|
|
|
local p_width = page_div.get_width() - 2
|
|
|
|
|
|
|
|
local main_page = app.new_page(nil, 1)
|
2024-06-07 03:05:22 +00:00
|
|
|
local search_page = app.new_page(main_page, 2)
|
|
|
|
local use_page = app.new_page(main_page, 3)
|
|
|
|
local uis_page = app.new_page(main_page, 4)
|
|
|
|
local fps_page = app.new_page(main_page, 5)
|
|
|
|
local gls_page = app.new_page(main_page, 6)
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-07 03:10:19 +00:00
|
|
|
local home = Div{parent=page_div,x=2}
|
2024-06-07 03:05:22 +00:00
|
|
|
local search = Div{parent=page_div,x=2}
|
2024-06-04 00:52:59 +00:00
|
|
|
local use = Div{parent=page_div,x=2,width=p_width}
|
|
|
|
local uis = Div{parent=page_div,x=2,width=p_width}
|
|
|
|
local fps = Div{parent=page_div,x=2,width=p_width}
|
2024-06-14 21:10:42 +00:00
|
|
|
local gls = Div{parent=page_div,x=2,width=p_width}
|
2024-06-07 03:05:22 +00:00
|
|
|
local panes = { home, search, use, uis, fps, gls }
|
2024-06-05 00:31:29 +00:00
|
|
|
|
|
|
|
local doc_map = {}
|
2024-06-13 00:01:31 +00:00
|
|
|
local search_db = {}
|
2024-06-07 02:30:55 +00:00
|
|
|
|
|
|
|
---@class _guide_section_constructor_data
|
2024-06-13 00:01:31 +00:00
|
|
|
local sect_construct_data = { app, page_div, panes, doc_map, search_db, btn_fg_bg, btn_active }
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-30 17:55:13 +00:00
|
|
|
TextBox{parent=home,y=1,text="cc-mek-scada Guide",alignment=ALIGN.CENTER}
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-07 03:10:19 +00:00
|
|
|
PushButton{parent=home,y=3,text="Search >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=search_page.nav_to}
|
|
|
|
PushButton{parent=home,y=5,text="System Usage >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=use_page.nav_to}
|
2024-06-04 00:21:54 +00:00
|
|
|
PushButton{parent=home,text="Operator UIs >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=uis_page.nav_to}
|
|
|
|
PushButton{parent=home,text="Front Panels >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=fps_page.nav_to}
|
2024-06-05 00:31:29 +00:00
|
|
|
PushButton{parent=home,text="Glossary >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=gls_page.nav_to}
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-30 17:55:13 +00:00
|
|
|
TextBox{parent=search,y=1,text="Search",alignment=ALIGN.CENTER}
|
2024-06-07 03:05:22 +00:00
|
|
|
|
2024-06-13 00:01:31 +00:00
|
|
|
local query_field = TextField{parent=search,x=1,y=3,width=18,fg_bg=cpair(colors.white,colors.gray)}
|
2024-06-07 03:05:22 +00:00
|
|
|
|
2024-06-13 00:01:31 +00:00
|
|
|
local func_ref = {}
|
|
|
|
|
|
|
|
PushButton{parent=search,x=20,y=3,text="GO",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=function()func_ref.run_search()end}
|
|
|
|
|
|
|
|
local search_results = ListBox{parent=search,x=1,y=5,scroll_height=200,nav_fg_bg=cpair(colors.lightGray,colors.gray),nav_active=cpair(colors.white,colors.gray)}
|
|
|
|
|
|
|
|
function func_ref.run_search()
|
|
|
|
local query = string.lower(query_field.get_value())
|
|
|
|
local s_results = { {}, {}, {} }
|
|
|
|
|
|
|
|
search_results.remove_all()
|
|
|
|
|
|
|
|
if string.len(query) < 3 then
|
2024-06-14 21:10:42 +00:00
|
|
|
TextBox{parent=search_results,text="Search requires at least 3 characters."}
|
2024-06-13 00:01:31 +00:00
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
for _, entry in ipairs(search_db) do
|
|
|
|
local s_start, _ = string.find(entry[1], query, 1, true)
|
|
|
|
|
|
|
|
if s_start == nil then
|
|
|
|
elseif s_start == 1 then
|
|
|
|
-- best match, start of key
|
|
|
|
table.insert(s_results[1], entry)
|
|
|
|
elseif string.sub(query, s_start - 1, s_start) == " " then
|
|
|
|
-- start of word, good match
|
|
|
|
table.insert(s_results[2], entry)
|
|
|
|
else
|
|
|
|
-- basic match in content
|
|
|
|
table.insert(s_results[3], entry)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
local empty = true
|
|
|
|
|
|
|
|
for tier = 1, 3 do
|
|
|
|
for idx = 1, #s_results[tier] do
|
|
|
|
local entry = s_results[tier][idx]
|
|
|
|
TextBox{parent=search_results,text=entry[3].." >",fg_bg=cpair(colors.gray,colors.black)}
|
|
|
|
PushButton{parent=search_results,text=entry[2],alignment=ALIGN.LEFT,fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=entry[4]}
|
|
|
|
|
|
|
|
empty = false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
if empty then
|
|
|
|
TextBox{parent=search_results,text="No results found."}
|
|
|
|
end
|
|
|
|
end
|
2024-06-07 03:05:22 +00:00
|
|
|
|
|
|
|
TextBox{parent=search_results,text="Click 'GO' to search..."}
|
|
|
|
|
2024-06-14 01:43:56 +00:00
|
|
|
util.nop()
|
|
|
|
|
2024-06-30 17:55:13 +00:00
|
|
|
TextBox{parent=use,y=1,text="System Usage",alignment=ALIGN.CENTER}
|
2024-06-04 00:21:54 +00:00
|
|
|
PushButton{parent=use,x=2,y=1,text="<",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=main_page.nav_to}
|
|
|
|
|
2024-06-07 02:30:55 +00:00
|
|
|
PushButton{parent=use,y=3,text="Configuring Devices >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,dis_fg_bg=btn_disable,callback=function()end}.disable()
|
|
|
|
PushButton{parent=use,text="Connecting Devices >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,dis_fg_bg=btn_disable,callback=function()end}.disable()
|
|
|
|
PushButton{parent=use,text="Manual Control >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,dis_fg_bg=btn_disable,callback=function()end}.disable()
|
|
|
|
PushButton{parent=use,text="Automatic Control >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,dis_fg_bg=btn_disable,callback=function()end}.disable()
|
|
|
|
PushButton{parent=use,text="Waste Control >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,dis_fg_bg=btn_disable,callback=function()end}.disable()
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-30 17:55:13 +00:00
|
|
|
TextBox{parent=uis,y=1,text="Operator UIs",alignment=ALIGN.CENTER}
|
2024-06-04 00:21:54 +00:00
|
|
|
PushButton{parent=uis,x=2,y=1,text="<",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=main_page.nav_to}
|
|
|
|
|
2024-06-05 00:31:29 +00:00
|
|
|
local annunc_page = app.new_page(uis_page, #panes + 1)
|
|
|
|
local annunc_div = Div{parent=page_div,x=2}
|
|
|
|
table.insert(panes, annunc_div)
|
|
|
|
|
2024-06-07 02:54:26 +00:00
|
|
|
local alarms_page = guide_section(sect_construct_data, uis_page, "Alarms", docs.alarms, 100)
|
2024-06-07 02:30:55 +00:00
|
|
|
|
2024-06-05 00:31:29 +00:00
|
|
|
PushButton{parent=uis,y=3,text="Alarms >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=alarms_page.nav_to}
|
|
|
|
PushButton{parent=uis,text="Annunciators >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=annunc_page.nav_to}
|
2024-06-07 02:30:55 +00:00
|
|
|
PushButton{parent=uis,text="Pocket UI >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,dis_fg_bg=btn_disable,callback=function()end}.disable()
|
|
|
|
PushButton{parent=uis,text="Coordinator UI >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,dis_fg_bg=btn_disable,callback=function()end}.disable()
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-30 17:55:13 +00:00
|
|
|
TextBox{parent=annunc_div,y=1,text="Annunciators",alignment=ALIGN.CENTER}
|
2024-06-07 02:30:55 +00:00
|
|
|
PushButton{parent=annunc_div,x=2,y=1,text="<",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=uis_page.nav_to}
|
|
|
|
|
2024-06-14 21:49:43 +00:00
|
|
|
local unit_gen_page = guide_section(sect_construct_data, annunc_page, "Unit General", docs.annunc.unit.main_section, 170)
|
2024-06-07 02:54:26 +00:00
|
|
|
local unit_rps_page = guide_section(sect_construct_data, annunc_page, "Unit RPS", docs.annunc.unit.rps_section, 100)
|
2024-06-14 21:49:43 +00:00
|
|
|
local unit_rcs_page = guide_section(sect_construct_data, annunc_page, "Unit RCS", docs.annunc.unit.rcs_section, 170)
|
2024-06-29 18:59:39 +00:00
|
|
|
local fac_annunc_page = guide_section(sect_construct_data, annunc_page, "Facility", docs.annunc.unit.fac_section, 100)
|
2024-06-07 02:30:55 +00:00
|
|
|
|
|
|
|
PushButton{parent=annunc_div,y=3,text="Unit General >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=unit_gen_page.nav_to}
|
|
|
|
PushButton{parent=annunc_div,text="Unit RPS >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=unit_rps_page.nav_to}
|
|
|
|
PushButton{parent=annunc_div,text="Unit RCS >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=unit_rcs_page.nav_to}
|
2024-06-29 18:59:39 +00:00
|
|
|
PushButton{parent=annunc_div,text="Facility General >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=fac_annunc_page.nav_to}
|
2024-06-07 02:30:55 +00:00
|
|
|
PushButton{parent=annunc_div,text="Waste & Valves >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,dis_fg_bg=btn_disable,callback=function()end}.disable()
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-30 17:55:13 +00:00
|
|
|
TextBox{parent=fps,y=1,text="Front Panels",alignment=ALIGN.CENTER}
|
2024-06-04 00:21:54 +00:00
|
|
|
PushButton{parent=fps,x=2,y=1,text="<",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=main_page.nav_to}
|
|
|
|
|
2024-06-07 02:30:55 +00:00
|
|
|
PushButton{parent=fps,y=3,text="Common Items >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,dis_fg_bg=btn_disable,callback=function()end}.disable()
|
|
|
|
PushButton{parent=fps,text="Reactor PLC >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,dis_fg_bg=btn_disable,callback=function()end}.disable()
|
|
|
|
PushButton{parent=fps,text="RTU Gateway >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,dis_fg_bg=btn_disable,callback=function()end}.disable()
|
|
|
|
PushButton{parent=fps,text="Supervisor >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,dis_fg_bg=btn_disable,callback=function()end}.disable()
|
|
|
|
PushButton{parent=fps,text="Coordinator >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,dis_fg_bg=btn_disable,callback=function()end}.disable()
|
2024-06-04 00:21:54 +00:00
|
|
|
|
2024-06-30 17:55:13 +00:00
|
|
|
TextBox{parent=gls,y=1,text="Glossary",alignment=ALIGN.CENTER}
|
2024-06-05 00:31:29 +00:00
|
|
|
PushButton{parent=gls,x=3,y=1,text="<",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=main_page.nav_to}
|
|
|
|
|
2024-07-06 04:07:21 +00:00
|
|
|
local gls_abbv_page = guide_section(sect_construct_data, gls_page, "Abbreviations", docs.glossary.abbvs, 130)
|
2024-06-07 02:54:26 +00:00
|
|
|
local gls_term_page = guide_section(sect_construct_data, gls_page, "Terminology", docs.glossary.terms, 100)
|
2024-06-05 23:38:02 +00:00
|
|
|
|
2024-06-07 02:30:55 +00:00
|
|
|
PushButton{parent=gls,y=3,text="Abbreviations >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=gls_abbv_page.nav_to}
|
|
|
|
PushButton{parent=gls,text="Terminology >",fg_bg=btn_fg_bg,active_fg_bg=btn_active,callback=gls_term_page.nav_to}
|
2024-06-05 00:31:29 +00:00
|
|
|
|
2024-06-04 00:21:54 +00:00
|
|
|
-- setup multipane
|
2024-06-04 00:52:59 +00:00
|
|
|
local u_pane = MultiPane{parent=page_div,x=1,y=1,panes=panes}
|
2024-06-04 00:21:54 +00:00
|
|
|
app.set_root_pane(u_pane)
|
2024-06-07 02:30:55 +00:00
|
|
|
|
|
|
|
-- link help resources
|
|
|
|
db.nav.link_help(doc_map)
|
2024-06-14 01:43:56 +00:00
|
|
|
|
|
|
|
-- done, show the app
|
|
|
|
load_pane.set_value(2)
|
2024-06-04 00:21:54 +00:00
|
|
|
end
|
|
|
|
|
2024-06-14 16:10:04 +00:00
|
|
|
-- delete the elements and switch back to the loading screen
|
|
|
|
local function unload()
|
|
|
|
if page_div then
|
|
|
|
page_div.delete()
|
|
|
|
page_div = nil
|
|
|
|
end
|
|
|
|
|
|
|
|
app.set_sidebar({ { label = " # ", tall = true, color = core.cpair(colors.black, colors.green), callback = function () db.nav.open_app(APP_ID.ROOT) end } })
|
|
|
|
app.delete_pages()
|
|
|
|
|
|
|
|
-- show loading screen
|
|
|
|
load_pane.set_value(1)
|
|
|
|
end
|
|
|
|
|
|
|
|
app.set_load(load)
|
|
|
|
app.set_unload(unload)
|
2024-06-04 00:21:54 +00:00
|
|
|
|
|
|
|
return main
|
|
|
|
end
|
|
|
|
|
|
|
|
return new_view
|