1
0
mirror of https://github.com/ComfyFactory/ComfyFactorio.git synced 2025-01-04 00:15:45 +02:00
ComfyFactorio/utils/gui.lua

835 lines
24 KiB
Lua
Raw Normal View History

2019-02-26 21:25:59 +02:00
local Token = require 'utils.token'
2018-09-19 06:51:25 +02:00
local Event = require 'utils.event'
2019-02-26 21:25:59 +02:00
local Global = require 'utils.global'
2021-10-23 00:04:48 +02:00
local mod_gui = require('__core__/lualib/mod-gui')
2022-04-05 19:28:08 +02:00
local Server = require 'utils.server'
local SpamProtection = require 'utils.spam_protection'
2018-09-19 06:51:25 +02:00
2020-07-25 17:22:04 +02:00
local tostring = tostring
local next = next
2022-04-05 19:28:08 +02:00
local Public = {}
2018-09-19 06:51:25 +02:00
2022-04-05 19:28:08 +02:00
-- local to this file
local main_gui_tabs = {}
local screen_elements = {}
local on_visible_handlers = {}
local on_pre_hidden_handlers = {}
-- global
2019-02-26 21:25:59 +02:00
local data = {}
2020-07-25 17:22:04 +02:00
local element_map = {}
2022-04-05 19:28:08 +02:00
local settings = {
2022-04-08 22:39:15 +02:00
mod_gui_top_frame = false,
disabled_tabs = {}
2022-04-05 19:28:08 +02:00
}
2018-09-19 06:51:25 +02:00
2022-04-05 19:28:08 +02:00
Public.token =
2020-07-25 17:22:04 +02:00
Global.register(
2021-05-23 17:03:52 +02:00
{data = data, element_map = element_map, settings = settings},
2019-02-26 21:25:59 +02:00
function(tbl)
2020-07-25 17:22:04 +02:00
data = tbl.data
element_map = tbl.element_map
2021-05-23 17:03:52 +02:00
settings = tbl.settings
2018-09-19 06:51:25 +02:00
end
2019-02-26 21:25:59 +02:00
)
2022-07-10 20:27:18 +02:00
Public.beam = 'file/utils/files/beam.png'
2022-04-05 19:28:08 +02:00
Public.settings_white_icon = 'file/utils/files/settings-white.png'
Public.settings_black_icon = 'file/utils/files/settings-black.png'
Public.pin_white_icon = 'file/utils/files/pin-white.png'
Public.pin_black_icon = 'file/utils/files/pin-black.png'
Public.infinite_icon = 'file/utils/files/infinity.png'
Public.arrow_up_icon = 'file/utils/files/arrow-up.png'
Public.arrow_down_icon = 'file/utils/files/arrow-down.png'
2022-04-18 01:18:06 +02:00
Public.info_icon = 'file/utils/files/info.png'
2019-02-26 21:25:59 +02:00
2022-04-05 19:28:08 +02:00
function Public.uid_name()
2021-04-04 13:51:27 +02:00
return tostring(Token.uid())
2018-09-19 06:51:25 +02:00
end
2022-04-05 19:28:08 +02:00
function Public.uid()
2020-08-31 20:37:27 +02:00
return Token.uid()
end
2022-04-05 19:28:08 +02:00
local main_frame_name = Public.uid_name()
local main_button_name = Public.uid_name()
local close_button_name = Public.uid_name()
2022-09-22 20:42:46 +02:00
Public.top_main_gui_button = main_button_name
Public.main_frame_name = main_frame_name
2022-08-12 19:13:48 +02:00
--- Verifies if a frame is valid and destroys it.
---@param align userdata
---@param frame userdata
local function validate_frame_and_destroy(align, frame)
local get_frame = align[frame]
if get_frame and get_frame.valid then
get_frame.destroy()
end
end
2018-09-19 06:51:25 +02:00
-- Associates data with the LuaGuiElement. If data is nil then removes the data
2022-04-05 19:28:08 +02:00
function Public.set_data(element, value)
2020-07-25 17:22:04 +02:00
local player_index = element.player_index
local values = data[player_index]
if value == nil then
if not values then
return
end
2021-04-04 13:51:27 +02:00
values[element.index] = nil
2020-07-25 17:22:04 +02:00
if next(values) == nil then
data[player_index] = nil
end
else
if not values then
values = {}
data[player_index] = values
end
2021-04-04 13:51:27 +02:00
values[element.index] = value
2020-07-25 17:22:04 +02:00
end
2018-09-19 06:51:25 +02:00
end
2022-04-05 19:28:08 +02:00
local set_data = Public.set_data
2018-09-19 06:51:25 +02:00
-- Gets the Associated data with this LuaGuiElement if any.
2022-04-05 19:28:08 +02:00
function Public.get_data(element)
2021-06-06 20:14:26 +02:00
if not element then
return
end
2020-07-25 17:22:04 +02:00
local player_index = element.player_index
local values = data[player_index]
if not values then
return nil
end
return values[element.index]
2018-09-19 06:51:25 +02:00
end
2022-04-05 19:28:08 +02:00
-- Adds a gui that is alike the factorio native gui.
2022-08-12 19:13:48 +02:00
function Public.add_main_frame_with_toolbar(player, align, set_frame_name, set_settings_button_name, close_main_frame_name, name, info, inside_table_count)
2022-04-05 19:28:08 +02:00
if not align then
return
end
local main_frame
if align == 'left' then
2022-08-12 19:13:48 +02:00
validate_frame_and_destroy(player.gui.left, set_frame_name)
2022-04-05 19:28:08 +02:00
main_frame = player.gui.left.add {type = 'frame', name = set_frame_name, direction = 'vertical'}
elseif align == 'center' then
2022-08-12 19:13:48 +02:00
validate_frame_and_destroy(player.gui.center, set_frame_name)
2022-04-05 19:28:08 +02:00
main_frame = player.gui.center.add {type = 'frame', name = set_frame_name, direction = 'vertical'}
elseif align == 'screen' then
2022-08-12 19:13:48 +02:00
validate_frame_and_destroy(player.gui.screen, set_frame_name)
2022-04-05 19:28:08 +02:00
main_frame = player.gui.screen.add {type = 'frame', name = set_frame_name, direction = 'vertical'}
end
local titlebar = main_frame.add {type = 'flow', name = 'titlebar', direction = 'horizontal'}
titlebar.style.horizontal_spacing = 8
titlebar.style = 'horizontal_flow'
if align == 'screen' then
titlebar.drag_target = main_frame
end
titlebar.add {
type = 'label',
name = 'main_label',
style = 'frame_title',
caption = name,
ignored_by_interaction = true
}
local widget = titlebar.add {type = 'empty-widget', style = 'draggable_space', ignored_by_interaction = true}
widget.style.left_margin = 4
widget.style.right_margin = 4
widget.style.height = 24
widget.style.horizontally_stretchable = true
if set_settings_button_name then
2022-04-18 01:18:06 +02:00
if not info then
titlebar.add {
type = 'sprite-button',
name = set_settings_button_name,
style = 'frame_action_button',
sprite = Public.settings_white_icon,
mouse_button_filter = {'left'},
hovered_sprite = Public.settings_black_icon,
clicked_sprite = Public.settings_black_icon,
tooltip = 'Settings',
tags = {
action = 'open_settings_gui'
}
2022-04-05 19:28:08 +02:00
}
2022-04-18 01:18:06 +02:00
else
titlebar.add {
type = 'sprite-button',
name = set_settings_button_name,
style = 'frame_action_button',
sprite = Public.info_icon,
mouse_button_filter = {'left'},
hovered_sprite = Public.info_icon,
clicked_sprite = Public.info_icon,
tooltip = 'Info',
tags = {
action = 'open_settings_gui'
}
}
end
2022-04-05 19:28:08 +02:00
end
if close_main_frame_name then
titlebar.add {
type = 'sprite-button',
name = close_main_frame_name,
style = 'frame_action_button',
mouse_button_filter = {'left'},
sprite = 'utility/close_white',
hovered_sprite = 'utility/close_black',
clicked_sprite = 'utility/close_black',
tooltip = 'Close',
tags = {
action = 'close_main_frame_gui'
}
}
end
local inside_frame =
main_frame.add {
type = 'frame',
2022-04-18 01:18:06 +02:00
style = 'inside_shallow_frame'
2022-04-05 19:28:08 +02:00
}
local inside_frame_style = inside_frame.style
inside_frame_style.vertically_stretchable = true
inside_frame_style.maximal_height = 800
local inside_table =
inside_frame.add {
type = 'table',
2022-08-12 19:13:48 +02:00
column_count = 1 or inside_table_count,
2022-04-05 19:28:08 +02:00
name = 'inside_frame'
}
inside_table.style.padding = 3
return main_frame, inside_table
end
2020-07-25 17:22:04 +02:00
local remove_data_recursively
2019-02-26 21:25:59 +02:00
-- Removes data associated with LuaGuiElement and its children recursively.
2022-04-05 19:28:08 +02:00
function Public.remove_data_recursively(element)
2020-07-25 17:22:04 +02:00
set_data(element, nil)
2018-09-19 06:51:25 +02:00
local children = element.children
if not children then
return
end
2020-07-25 17:22:04 +02:00
for _, child in next, children do
2018-09-19 06:51:25 +02:00
if child.valid then
2020-07-25 17:22:04 +02:00
remove_data_recursively(child)
2018-09-19 06:51:25 +02:00
end
end
end
2022-04-05 19:28:08 +02:00
remove_data_recursively = Public.remove_data_recursively
2018-09-19 06:51:25 +02:00
2020-07-25 17:22:04 +02:00
local remove_children_data
2022-04-05 19:28:08 +02:00
function Public.remove_children_data(element)
2018-09-19 06:51:25 +02:00
local children = element.children
if not children then
return
end
2020-07-25 17:22:04 +02:00
for _, child in next, children do
2018-09-19 06:51:25 +02:00
if child.valid then
2020-07-25 17:22:04 +02:00
set_data(child, nil)
remove_children_data(child)
2018-09-19 06:51:25 +02:00
end
end
end
2022-04-05 19:28:08 +02:00
remove_children_data = Public.remove_children_data
2018-09-19 06:51:25 +02:00
2022-04-05 19:28:08 +02:00
function Public.destroy(element)
2020-07-25 17:22:04 +02:00
remove_data_recursively(element)
2018-09-19 06:51:25 +02:00
element.destroy()
end
2022-04-05 19:28:08 +02:00
function Public.clear(element)
2020-07-25 17:22:04 +02:00
remove_children_data(element)
2018-09-19 06:51:25 +02:00
element.clear()
end
2021-05-23 17:03:52 +02:00
local function clear_invalid_data()
if settings.disable_clear_invalid_data then
return
end
for _, player in pairs(game.players) do
2020-09-12 19:16:38 +02:00
local player_index = player.index
local values = data[player_index]
if values then
2021-05-23 17:03:52 +02:00
for k, element in next, values do
2020-09-12 19:16:38 +02:00
if type(element) == 'table' then
for key, obj in next, element do
if type(obj) == 'table' and obj.valid ~= nil then
if not obj.valid then
element[key] = nil
end
end
end
2021-05-23 17:03:52 +02:00
if type(element) == 'userdata' and not element.valid then
values[k] = nil
end
2020-09-12 19:16:38 +02:00
end
end
end
end
end
Event.on_nth_tick(300, clear_invalid_data)
2018-09-19 06:51:25 +02:00
local function handler_factory(event_id)
local handlers
local function on_event(event)
local element = event.element
if not element or not element.valid then
return
end
local handler = handlers[element.name]
if not handler then
return
end
2020-07-25 17:22:04 +02:00
local player = game.get_player(event.player_index)
2020-12-14 20:36:37 +02:00
if not (player and player.valid) then
2018-09-19 06:51:25 +02:00
return
end
2021-01-12 22:52:45 +02:00
2018-09-19 06:51:25 +02:00
event.player = player
handler(event)
end
return function(element_name, handler)
if not handlers then
handlers = {}
Event.add(event_id, on_event)
end
handlers[element_name] = handler
end
end
2019-02-26 21:25:59 +02:00
local function custom_handler_factory(handlers)
return function(element_name, handler)
handlers[element_name] = handler
end
end
2021-03-24 21:14:55 +02:00
--luacheck: ignore custom_raise
2022-04-07 16:11:57 +02:00
---@diagnostic disable-next-line: unused-function, unused-local
2019-02-26 21:25:59 +02:00
local function custom_raise(handlers, element, player)
local handler = handlers[element.name]
if not handler then
return
end
handler({element = element, player = player})
end
2021-05-23 17:03:52 +02:00
-- Disabled the handler so it does not clean then data table of invalid data.
2022-04-05 19:28:08 +02:00
function Public.set_disable_clear_invalid_data(value)
2021-05-23 17:03:52 +02:00
settings.disable_clear_invalid_data = value or false
end
-- Gets state if the cleaner handler is active or false
2022-04-05 19:28:08 +02:00
function Public.get_disable_clear_invalid_data()
2021-05-23 17:03:52 +02:00
return settings.disable_clear_invalid_data
end
2022-04-08 22:39:15 +02:00
-- Disable a gui.
---@param frame_name string
---@param state boolean?
function Public.set_disabled_tab(frame_name, state)
if not frame_name then
return
end
settings.disabled_tabs[frame_name] = state or false
end
-- Fetches if a gui is disabled.
---@param frame_name string
function Public.get_disabled_tab(frame_name)
if not frame_name then
return
end
return settings.disabled_tabs[frame_name]
end
2022-04-05 19:28:08 +02:00
-- Fetches the main frame name
function Public.get_main_frame(player)
if not player then
return false
end
local left = player.gui.left
local frame = left[main_frame_name]
if frame and frame.valid then
local inside_frame = frame.children[2]
if inside_frame and inside_frame.valid then
local inside_table = inside_frame.children[1]
if inside_table and inside_table.valid then
return inside_table
end
end
return false
end
return false
end
-- Fetches the parent frame name
function Public.get_parent_frame(player)
if not player then
return false
end
local left = player.gui.left
local frame = left[main_frame_name]
if frame and frame.valid then
return frame
end
return false
end
--- This adds the given gui to the top gui.
2022-04-07 16:11:57 +02:00
---@param player userdata
2022-07-11 00:14:21 +02:00
---@param frame userdata|table
2022-04-05 19:28:08 +02:00
function Public.add_mod_button(player, frame)
if Public.get_button_flow(player)[frame.name] and Public.get_button_flow(player)[frame.name].valid then
return
end
Public.get_button_flow(player).add(frame)
end
2022-04-07 16:11:57 +02:00
---@param state boolean
2022-04-05 19:28:08 +02:00
--- If we should use the new mod gui or not
function Public.set_mod_gui_top_frame(state)
settings.mod_gui_top_frame = state or false
end
--- Get mod_gui_top_frame
function Public.get_mod_gui_top_frame()
return settings.mod_gui_top_frame
end
--- This adds the given gui to the main gui.
2022-04-07 16:11:57 +02:00
---@param tbl table
2022-04-05 19:28:08 +02:00
function Public.add_tab_to_gui(tbl)
if not tbl then
return
end
if not tbl.name then
return
end
if not tbl.caption then
return
end
if not tbl.id then
return
end
local admin = tbl.admin or false
local only_server_sided = tbl.only_server_sided or false
if not main_gui_tabs[tbl.caption] then
main_gui_tabs[tbl.caption] = {id = tbl.id, name = tbl.name, admin = admin, only_server_sided = only_server_sided}
else
error('Given name: ' .. tbl.caption .. ' already exists in table.')
end
end
function Public.screen_to_bypass(elem)
screen_elements[elem] = true
return screen_elements
end
--- Fetches the main gui tabs. You are forbidden to write as this is local.
2022-04-07 16:11:57 +02:00
---@param key string
2022-04-05 19:28:08 +02:00
function Public.get(key)
if key then
return main_gui_tabs[key]
else
return main_gui_tabs
end
end
function Public.clear_main_frame(player)
if not player then
return
end
local frame = Public.get_main_frame(player)
if frame then
frame.destroy()
end
end
2022-04-18 01:18:06 +02:00
function Public.clear_all_center_frames(player)
for _, child in pairs(player.gui.center.children) do
child.destroy()
end
end
function Public.clear_all_screen_frames(player)
for _, child in pairs(player.gui.screen.children) do
if not screen_elements[child.name] then
child.destroy()
end
end
end
2022-04-05 19:28:08 +02:00
function Public.clear_all_active_frames(player)
for _, child in pairs(player.gui.left.children) do
child.destroy()
end
for _, child in pairs(player.gui.screen.children) do
if not screen_elements[child.name] then
child.destroy()
end
end
end
function Public.get_player_active_frame(player)
local main_frame = Public.get_main_frame(player)
if not main_frame then
return false
end
local panel = main_frame.tabbed_pane
if not panel then
return
end
local index = panel.selected_tab_index
if not index then
return panel.tabs[1].content
end
return panel.tabs[index].content
end
local function get_player_active_tab(player)
local main_frame = Public.get_main_frame(player)
if not main_frame then
return false
end
local panel = main_frame.tabbed_pane
if not panel then
return
end
local index = panel.selected_tab_index
if not index then
return panel.tabs[1].tab, panel.tabs[1].content
end
return panel.tabs[index].tab, panel.tabs[index].content
end
function Public.reload_active_tab(player, forced)
local is_spamming = SpamProtection.is_spamming(player, nil, 'Reload active tab')
if is_spamming and not forced then
return
end
local frame, main_tab = get_player_active_tab(player)
if not frame then
return
end
local tab = main_gui_tabs[frame.caption]
if not tab then
return
end
local id = tab.id
if not id then
return
end
local func = Token.get(id)
local d = {
player = player,
frame = main_tab
}
return func(d)
end
local function top_button(player)
if settings.mod_gui_top_frame then
Public.add_mod_button(player, {type = 'sprite-button', name = main_button_name, sprite = 'item/raw-fish'})
else
if player.gui.top[main_button_name] then
return
end
local button = player.gui.top.add({type = 'sprite-button', name = main_button_name, sprite = 'item/raw-fish'})
button.style.minimal_height = 38
button.style.maximal_height = 38
button.style.minimal_width = 40
button.style.padding = -2
end
end
local function draw_main_frame(player)
local tabs = main_gui_tabs
2022-06-10 22:06:35 +02:00
2022-04-05 19:28:08 +02:00
Public.clear_all_active_frames(player)
if Public.get_main_frame(player) then
Public.get_main_frame(player).destroy()
end
2022-04-05 19:41:44 +02:00
local frame, inside_frame = Public.add_main_frame_with_toolbar(player, 'left', main_frame_name, nil, close_button_name, 'Comfy Panel')
2022-04-05 19:28:08 +02:00
local tabbed_pane = inside_frame.add({type = 'tabbed-pane', name = 'tabbed_pane'})
for name, func in pairs(tabs) do
2022-04-08 22:39:15 +02:00
if not settings.disabled_tabs[name] then
if func.only_server_sided then
local secs = Server.get_current_time()
if secs then
local tab = tabbed_pane.add({type = 'tab', caption = name, name = func.name})
local name_frame = tabbed_pane.add({type = 'frame', name = name, direction = 'vertical'})
name_frame.style.minimal_height = 480
name_frame.style.maximal_height = 480
name_frame.style.minimal_width = 800
name_frame.style.maximal_width = 800
tabbed_pane.add_tab(tab, name_frame)
end
elseif func.admin == true then
if player.admin then
local tab = tabbed_pane.add({type = 'tab', caption = name, name = func.name})
local name_frame = tabbed_pane.add({type = 'frame', name = name, direction = 'vertical'})
name_frame.style.minimal_height = 480
name_frame.style.maximal_height = 480
name_frame.style.minimal_width = 800
name_frame.style.maximal_width = 800
tabbed_pane.add_tab(tab, name_frame)
end
else
2022-04-05 19:28:08 +02:00
local tab = tabbed_pane.add({type = 'tab', caption = name, name = func.name})
local name_frame = tabbed_pane.add({type = 'frame', name = name, direction = 'vertical'})
name_frame.style.minimal_height = 480
name_frame.style.maximal_height = 480
name_frame.style.minimal_width = 800
name_frame.style.maximal_width = 800
tabbed_pane.add_tab(tab, name_frame)
end
end
end
for _, child in pairs(tabbed_pane.children) do
child.style.padding = 8
child.style.left_padding = 2
child.style.right_padding = 2
end
Public.reload_active_tab(player, true)
return frame, inside_frame
end
function Public.call_existing_tab(player, name)
local frame, inside_frame = draw_main_frame(player)
if not frame then
return
end
2022-10-26 00:05:47 +02:00
if not inside_frame then
return
end
2022-04-05 19:28:08 +02:00
local tabbed_pane = inside_frame.tabbed_pane
for key, v in pairs(tabbed_pane.tabs) do
if v.tab.caption == name then
tabbed_pane.selected_tab_index = key
Public.reload_active_tab(player, true)
end
end
end
2018-09-19 06:51:25 +02:00
-- Register a handler for the on_gui_checked_state_changed event for LuaGuiElements with element_name.
-- Can only have one handler per element name.
-- Guarantees that the element and the player are valid when calling the handler.
-- Adds a player field to the event table.
2022-04-05 19:28:08 +02:00
Public.on_checked_state_changed = handler_factory(defines.events.on_gui_checked_state_changed)
2018-09-19 06:51:25 +02:00
-- Register a handler for the on_gui_click event for LuaGuiElements with element_name.
-- Can only have one handler per element name.
-- Guarantees that the element and the player are valid when calling the handler.
-- Adds a player field to the event table.
2022-04-05 19:28:08 +02:00
Public.on_click = handler_factory(defines.events.on_gui_click)
2018-09-19 06:51:25 +02:00
-- Register a handler for the on_gui_closed event for a custom LuaGuiElements with element_name.
-- Can only have one handler per element name.
-- Guarantees that the element and the player are valid when calling the handler.
-- Adds a player field to the event table.
2022-04-05 19:28:08 +02:00
Public.on_custom_close = handler_factory(defines.events.on_gui_closed)
2018-09-19 06:51:25 +02:00
-- Register a handler for the on_gui_elem_changed event for LuaGuiElements with element_name.
-- Can only have one handler per element name.
-- Guarantees that the element and the player are valid when calling the handler.
-- Adds a player field to the event table.
2022-04-05 19:28:08 +02:00
Public.on_elem_changed = handler_factory(defines.events.on_gui_elem_changed)
2018-09-19 06:51:25 +02:00
-- Register a handler for the on_gui_selection_state_changed event for LuaGuiElements with element_name.
-- Can only have one handler per element name.
-- Guarantees that the element and the player are valid when calling the handler.
-- Adds a player field to the event table.
2022-04-05 19:28:08 +02:00
Public.on_selection_state_changed = handler_factory(defines.events.on_gui_selection_state_changed)
2018-09-19 06:51:25 +02:00
-- Register a handler for the on_gui_text_changed event for LuaGuiElements with element_name.
-- Can only have one handler per element name.
-- Guarantees that the element and the player are valid when calling the handler.
-- Adds a player field to the event table.
2022-04-05 19:28:08 +02:00
Public.on_text_changed = handler_factory(defines.events.on_gui_text_changed)
2018-09-19 06:51:25 +02:00
-- Register a handler for the on_gui_value_changed event for LuaGuiElements with element_name.
-- Can only have one handler per element name.
-- Guarantees that the element and the player are valid when calling the handler.
-- Adds a player field to the event table.
2022-04-05 19:28:08 +02:00
Public.on_value_changed = handler_factory(defines.events.on_gui_value_changed)
2018-09-19 06:51:25 +02:00
2019-02-26 21:25:59 +02:00
-- Register a handler for when the player shows the top LuaGuiElements with element_name.
2022-04-05 19:28:08 +02:00
-- Assuming the element_name has been added with Public.allow_player_to_toggle_top_element_visibility.
2019-02-26 21:25:59 +02:00
-- Can only have one handler per element name.
-- Guarantees that the element and the player are valid when calling the handler.
-- Adds a player field to the event table.
2022-04-05 19:28:08 +02:00
Public.on_player_show_top = custom_handler_factory(on_visible_handlers)
2019-02-26 21:25:59 +02:00
-- Register a handler for when the player hides the top LuaGuiElements with element_name.
2022-04-05 19:28:08 +02:00
-- Assuming the element_name has been added with Public.allow_player_to_toggle_top_element_visibility.
2019-02-26 21:25:59 +02:00
-- Can only have one handler per element name.
-- Guarantees that the element and the player are valid when calling the handler.
-- Adds a player field to the event table.
2022-04-05 19:28:08 +02:00
Public.on_pre_player_hide_top = custom_handler_factory(on_pre_hidden_handlers)
2019-02-26 21:25:59 +02:00
2021-04-04 13:51:27 +02:00
if _DEBUG then
local concat = table.concat
local names = {}
2022-04-05 19:28:08 +02:00
Public.names = names
2021-04-04 13:51:27 +02:00
2022-04-05 19:28:08 +02:00
function Public.uid_name()
2021-04-04 13:51:27 +02:00
local info = debug.getinfo(2, 'Sl')
local filepath = info.source:match('^.+/currently%-playing/(.+)$'):sub(1, -5)
local line = info.currentline
2019-02-26 21:25:59 +02:00
2021-04-04 13:51:27 +02:00
local token = tostring(Token.uid())
local name = concat {token, ' - ', filepath, ':line:', line}
names[token] = name
return token
end
2022-04-05 19:28:08 +02:00
function Public.set_data(element, value)
2021-04-04 13:51:27 +02:00
local player_index = element.player_index
local values = data[player_index]
if value == nil then
if not values then
return
end
local index = element.index
values[index] = nil
element_map[index] = nil
if next(values) == nil then
data[player_index] = nil
end
else
if not values then
values = {}
data[player_index] = values
end
local index = element.index
values[index] = value
element_map[index] = element
end
end
2022-04-05 19:28:08 +02:00
set_data = Public.set_data
2021-04-04 13:51:27 +02:00
2022-04-05 19:28:08 +02:00
function Public.data()
2021-04-04 13:51:27 +02:00
return data
end
2022-04-05 19:28:08 +02:00
function Public.element_map()
2021-04-04 13:51:27 +02:00
return element_map
end
2021-03-28 17:01:39 +02:00
end
2021-04-04 13:51:27 +02:00
2022-04-05 19:28:08 +02:00
Public.get_button_flow = mod_gui.get_button_flow
Public.mod_button = mod_gui.get_button_flow
Public.on_click(
main_button_name,
function(event)
local is_spamming = SpamProtection.is_spamming(event.player, nil, 'Main button')
if is_spamming then
return
end
local player = event.player
local frame = Public.get_parent_frame(player)
if frame then
frame.destroy()
else
draw_main_frame(player)
end
end
)
Public.on_click(
close_button_name,
function(event)
local is_spamming = SpamProtection.is_spamming(event.player, nil, 'Main button')
if is_spamming then
return
end
local player = event.player
local frame = Public.get_parent_frame(player)
if frame then
frame.destroy()
end
end
)
Event.add(
defines.events.on_player_created,
function(event)
local player = game.get_player(event.player_index)
top_button(player)
end
)
Event.add(
defines.events.on_player_joined_game,
function(event)
local player = game.get_player(event.player_index)
top_button(player)
end
)
2021-10-23 00:04:48 +02:00
2022-04-05 19:28:08 +02:00
return Public