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

minor changes

This commit is contained in:
Gerkiz 2020-07-01 19:35:38 +02:00
parent 5f6a3df0b9
commit 04a9abb2f7
4 changed files with 172 additions and 82 deletions

View File

@ -1,10 +1,13 @@
--antigrief things made by mewmew
local event = require 'utils.event'
local Event = require 'utils.event'
local Jailed = require 'utils.jail_data'
local Tabs = require 'comfy_panel.main'
local AntiGrief = require 'antigrief'
local lower = string.lower
local gmatch = string.gmatch
local function admin_only_message(str)
for _, player in pairs(game.connected_players) do
if player.admin == true then
@ -193,6 +196,109 @@ local function create_mini_camera_gui(player, caption, position, surface)
camera.style.minimal_height = 480
end
local function filter_brackets(str)
return (string.find(str, '%[') ~= nil)
end
local function match_test(value, pattern)
return lower(value:gsub('-', ' ')):find(pattern)
end
local function draw_events(data)
local frame = data.frame
local antigrief = data.antigrief
local search_text = data.search_text or nil
local history = frame['admin_history_select'].items[frame['admin_history_select'].selected_index]
local history_index = {
['Capsule History'] = antigrief.capsule_history,
['Friendly Fire History'] = antigrief.friendly_fire_history,
['Mining History'] = antigrief.mining_history,
['Landfill History'] = antigrief.landfill_history,
['Corpse Looting History'] = antigrief.corpse_history
}
local scroll_pane
if frame.datalog then
frame.datalog.clear()
else
scroll_pane =
frame.add(
{
type = 'scroll-pane',
name = 'datalog',
direction = 'vertical',
horizontal_scroll_policy = 'never',
vertical_scroll_policy = 'auto'
}
)
scroll_pane.style.maximal_height = 200
end
local target_player_name = frame['admin_player_select'].items[frame['admin_player_select'].selected_index]
local finder
if game.players[target_player_name] then
local target_player = game.players[target_player_name].index
finder = target_player
end
for key, value in pairs(history_index[history]) do
if not finder then
finder = key
end
if key == finder then
for i = #value, 1, -1 do
if search_text then
if filter_brackets(search_text) then
goto continue
end
if not match_test(value[i], search_text) then
goto continue
end
end
frame.datalog.add(
{
type = 'label',
caption = history_index[history][finder][i],
tooltip = 'Click to open mini camera.'
}
)
::continue::
end
end
end
end
local function text_changed(event)
local element = event.element
if not element then
return
end
if not element.valid then
return
end
local antigrief = AntiGrief.get()
local player = game.players[event.player_index]
local frame = Tabs.comfy_panel_get_active_frame(player)
if not frame then
return
end
if frame.name ~= 'Admin' then
return
end
local data = {
frame = frame,
antigrief = antigrief,
search_text = element.text
}
draw_events(data)
end
local create_admin_panel = (function(player, frame)
local antigrief = AntiGrief.get()
frame.clear()
@ -344,7 +450,14 @@ local create_admin_panel = (function(player, frame)
return
end
local search_table = frame.add({type = 'table', column_count = 2})
search_table.add({type = 'label', caption = 'Search: '})
local search_text = search_table.add({type = 'textfield'})
search_text.style.width = 140
local l = frame.add({type = 'label', caption = '----------------------------------------------'})
l.style.font = 'default-listbox'
l.style.font_color = {r = 0.98, g = 0.66, b = 0.22}
local selected_index_2 = 1
if global.admin_panel_selected_history_index then
@ -360,62 +473,12 @@ local create_admin_panel = (function(player, frame)
drop_down_2.style.right_padding = 12
drop_down_2.style.left_padding = 12
local history = frame['admin_history_select'].items[frame['admin_history_select'].selected_index]
local history_index = {
['Capsule History'] = antigrief.capsule_history,
['Friendly Fire History'] = antigrief.friendly_fire_history,
['Mining History'] = antigrief.mining_history,
['Landfill History'] = antigrief.landfill_history,
['Corpse Looting History'] = antigrief.corpse_history
local data = {
frame = frame,
antigrief = antigrief
}
local t = frame.add({type = 'table', column_count = 1})
l.style.font = 'default-listbox'
l.style.font_color = {r = 0.98, g = 0.66, b = 0.22}
local scroll_pane =
t.add(
{
type = 'scroll-pane',
direction = 'vertical',
horizontal_scroll_policy = 'never',
vertical_scroll_policy = 'auto'
}
)
scroll_pane.style.maximal_height = 200
local target_player_name = frame['admin_player_select'].items[frame['admin_player_select'].selected_index]
if game.players[target_player_name] then
for k, v in pairs(history_index[history]) do
local target_player = game.players[target_player_name].index
if k == target_player then
for i = #v, 1, -1 do
scroll_pane.add(
{
type = 'label',
caption = history_index[history][target_player][i],
tooltip = 'Click to open mini camera.'
}
)
end
end
end
else
for k, v in pairs(history_index[history]) do
if history_index[history][k] ~= nil and history_index[history][k] ~= '' then
for i = #v, 1, -1 do
scroll_pane.add(
{
type = 'label',
caption = history_index[history][k][i],
tooltip = 'Click to open mini camera.'
}
)
end
end
end
end
draw_events(data)
end)
local admin_functions = {
@ -613,5 +676,6 @@ end
comfy_panel_tabs['Admin'] = {gui = create_admin_panel, admin = true}
event.add(defines.events.on_gui_click, on_gui_click)
event.add(defines.events.on_gui_selection_state_changed, on_gui_selection_state_changed)
Event.add(defines.events.on_gui_text_changed, text_changed)
Event.add(defines.events.on_gui_click, on_gui_click)
Event.add(defines.events.on_gui_selection_state_changed, on_gui_selection_state_changed)

View File

@ -253,7 +253,7 @@ local function close_market_gui(player)
end
end
local function redraw_market_items(gui, player)
local function redraw_market_items(gui, player, search_text)
if not validate_player(player) then
return
end
@ -268,6 +268,15 @@ local function redraw_market_items(gui, player)
local slider_value = math.ceil(this.players[player.index].data.slider.slider_value)
for item, data in pairs(Public.get_items()) do
if not search_text then
goto continue
end
if not search_text.text then
goto continue
end
if not string.lower(item:gsub('-', ' ')):find(search_text.text) then
goto continue
end
local item_count = data.stack * slider_value
local item_cost = data.price * slider_value
@ -298,6 +307,7 @@ local function redraw_market_items(gui, player)
if player_item_count < item_cost then
button.enabled = false
end
::continue::
end
end
@ -344,10 +354,18 @@ local function slider_changed(event)
end
slider_value = math.ceil(slider_value)
this.players[player.index].data.text_input.text = slider_value
redraw_market_items(this.players[player.index].data.item_frame, player)
redraw_market_items(this.players[player.index].data.item_frame, player, this.players[player.index].data.search_text)
end
local function text_changed(event)
local element = event.element
if not element then
return
end
if not element.valid then
return
end
local this = WPT.get()
local player = game.players[event.player_index]
@ -369,9 +387,7 @@ local function text_changed(event)
return
end
this.players[player.index].data.slider.slider_value = value
redraw_market_items(data.item_frame, player)
redraw_market_items(data.item_frame, player, data.search_text)
end
local function gui_opened(event)
@ -483,7 +499,7 @@ local function gui_opened(event)
this.players[player.index].data.item_frame = pane
this.players[player.index].data.coins_left = coinsleft
redraw_market_items(pane, player)
redraw_market_items(pane, player, search_text)
end
local function gui_click(event)
@ -514,7 +530,7 @@ local function gui_click(event)
if slider_value > 1 then
data.slider.slider_value = slider_value - 1
data.text_input.text = data.slider.slider_value
redraw_market_items(data.item_frame, player)
redraw_market_items(data.item_frame, player, data.search_text)
end
return
elseif name == 'more' then
@ -522,7 +538,7 @@ local function gui_click(event)
if slider_value <= 1e3 then
data.slider.slider_value = slider_value + 1
data.text_input.text = data.slider.slider_value
redraw_market_items(data.item_frame, player)
redraw_market_items(data.item_frame, player, data.search_text)
end
return
end
@ -570,7 +586,7 @@ local function gui_click(event)
this.health_upgrades = this.health_upgrades + item_count
rendering.set_text(this.health_text, 'HP: ' .. this.locomotive_health .. ' / ' .. this.locomotive_max_health)
redraw_market_items(data.item_frame, player)
redraw_market_items(data.item_frame, player, data.search_text)
redraw_coins_left(data.coins_left, player)
return
@ -605,7 +621,7 @@ local function gui_click(event)
only_in_alt_mode = true
}
redraw_market_items(data.item_frame, player)
redraw_market_items(data.item_frame, player, data.search_text)
redraw_coins_left(data.coins_left, player)
return
@ -627,7 +643,7 @@ local function gui_click(event)
this.xp_points_upgrade = this.xp_points_upgrade + item_count
this.train_upgrades = this.train_upgrades + item_count
redraw_market_items(data.item_frame, player)
redraw_market_items(data.item_frame, player, data.search_text)
redraw_coins_left(data.coins_left, player)
return
@ -664,7 +680,7 @@ local function gui_click(event)
this.upgrades.flame_turret.limit = this.upgrades.flame_turret.limit + item_count
this.upgrades.flame_turret.bought = this.upgrades.flame_turret.bought + item_count
redraw_market_items(data.item_frame, player)
redraw_market_items(data.item_frame, player, data.search_text)
redraw_coins_left(data.coins_left, player)
return
@ -692,7 +708,7 @@ local function gui_click(event)
this.upgrades.landmine.limit = this.upgrades.landmine.limit + item_count
this.upgrades.landmine.bought = this.upgrades.landmine.bought + item_count
redraw_market_items(data.item_frame, player)
redraw_market_items(data.item_frame, player, data.search_text)
redraw_coins_left(data.coins_left, player)
return
end
@ -707,7 +723,7 @@ local function gui_click(event)
RPG.rpg_reset_player(player, true)
redraw_market_items(data.item_frame, player)
redraw_market_items(data.item_frame, player, data.search_text)
redraw_coins_left(data.coins_left, player)
return
end
@ -722,7 +738,7 @@ local function gui_click(event)
player.insert({name = item.value, count = cost})
player.remove_item({name = name, count = inserted_count})
end
redraw_market_items(data.item_frame, player)
redraw_market_items(data.item_frame, player, data.search_text)
redraw_coins_left(data.coins_left, player)
end
end

View File

@ -34,6 +34,7 @@ local Collapse = require 'modules.collapse'
local Difficulty = require 'modules.difficulty_vote'
local Task = require 'utils.task'
local Alert = require 'utils.alert'
local AntiGrief = require 'antigrief'
--local HD = require 'modules.hidden_dimension.main'
local Public = {}
@ -199,6 +200,7 @@ function Public.reset_map()
local this = WPT.get()
local wave_defense_table = WD.get_table()
local get_score = Score.get_table()
local antigrief = AntiGrief.get()
for _, player in pairs(game.players) do
if player.controller_type == defines.controllers.editor then
@ -232,6 +234,8 @@ function Public.reset_map()
global.friendly_fire_history = {}
global.landfill_history = {}
global.mining_history = {}
AntiGrief.log_tree_harvest(true)
AntiGrief.whitelist_types('tree', true)
get_score.score_table = {}
Diff.difficulty_poll_closing_timeout = game.tick + 90000
Diff.difficulty_player_votes = {}
@ -543,7 +547,7 @@ local chunk_load = function()
if chunk_load_tick then
if chunk_load_tick < game.tick then
WPT.get().chunk_load_tick = nil
Task.set_queue_speed(1)
Task.set_queue_speed(4)
end
end
end

View File

@ -268,7 +268,10 @@ function Event.add_removable_function(event_name, func)
end
if Debug.is_closure(func) then
error('func cannot be a closure as that is a desync risk. Consider using Event.add_removable(event_name, token) instead.', 2)
error(
'func cannot be a closure as that is a desync risk. Consider using Event.add_removable(event_name, token) instead.',
2
)
end
local funcs = function_handlers[event_name]
@ -375,7 +378,10 @@ function Event.add_removable_nth_tick_function(tick, func)
end
if Debug.is_closure(func) then
error('func cannot be a closure as that is a desync risk. Consider using Event.add_removable_nth_tick(tick, token) instead.', 2)
error(
'func cannot be a closure as that is a desync risk. Consider using Event.add_removable_nth_tick(tick, token) instead.',
2
)
end
local funcs = function_nth_tick_handlers[tick]
@ -429,15 +435,15 @@ function Event.generate_event_name(name)
end
function Event.add_event_filter(event, filter)
local current_filters = script.get_event_filter(event)
local current_filters = script.get_event_filter(event)
if not current_filters then
current_filters = {filter}
else
table.insert(current_filters, filter)
end
if not current_filters then
current_filters = {filter}
else
table.insert(current_filters, filter)
end
script.set_event_filter(event, current_filters)
script.set_event_filter(event, current_filters)
end
local function add_handlers()